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图 灵 社 区 的 电子 书 没 有 采用 专 有 客 
户 端 ， 您 可 以 在 任意 设备 上 ， 用 自 
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阅读 。 

但 您 购买 的 电子 书 仅 供 您 个 人 使 用 ， 
未 经 授权 ， 不 得 进行 传播 。 

我 们 愿意 相信 读者 具有 这 样 的 良知 
和 觉悟 ， 与 我 们 共同 保护 知识 产权 。 
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世界 级 计算 机 科学 家 ， 佐 治 亚 理 工学 院 计算 
机 科学 系 教授 、 系 主任 ， 在 计算 复杂 性 和 交 
互 式 证 明 系统 领域 取得 了 一 系列 重要 研究 成 
果 ， 为 计算 机 界 所 熟知 。Fortnow 早 年 师 从 著 
名 的 理论 计算 机 科学 家 Michael Sipser， 获 麻 
省 理工 学 院 应 用 数学 博士 学 位 。 毕 业 后 曾 在 
西北 大 学 、 芝 加 哥 大 学 担任 教授 ， 之 前 还 做 
过 NEC 研 究 院 高 级 研究 员 。 他 是 知名 博客 
Computational Complexity 的 创办 者 ， 经 常 与 
他 人 共同 执笔 撰写 计算 复杂 性 方面 的 文章 。 


软件 工程 师 、 技 术 发 烧 友 、 模 范 消费 者 。 关 注 
动态 语言 、 云 计算 、 数 据 可 视 化 、 产 品 设计 等 
领域 。 
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内 容 提 要 


P/NP 问题 是 计算 机 科学 乃至 整个 数学 领域 最 重要 的 开放 问题 。 本 书 从 非 技 术 角度 介绍 了 
什么 是 P/NP 问题 、 它 丰富 的 历史 ， 以 及 对 于 人 机 交互 乃至 更 多 问题 的 数学 意义 。 在 这 本 趣味 
十 足 的 书 中 ， 作 者 首先 追溯 了 PNP 问题 是 如 何 产 生 的 ， 然 后 给 出 了 这 个 问题 的 许多 实例 ， 涉 

















及 经 济 学 、 物 理学 和 生物 学 在 内 的 多 个 学 科 。 接 下 来 探讨 了 涵盖 P/NP 难题 中 所 有 难度 等 级 的 









































问题 ， 从 寻找 游玩 迪士尼 乐园 所 有 景点 的 最 短路 线 ， 到 地 图 填 色 问题 ， 再 到 找 
互 为 好 友 的 一 群 人 。 本 书 深入 探寻 了 计算 能 够 做 到 什么 、 无 法 做 到 什么 ， 描 绘 
问题 的 益处 和 其 中 难以 预想 的 挑战 。 
本 书 读 来 引人入胜 ， 适 合 所 有 对 计算 和 数学 感 兴 趣 的 读者 。 
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献 给 Marcy, Annie fe Molly, 
愿 他 们 知道 我 是 做 什么 的 ， 以 及 为 何 而 做 。 


o 


英国 著名 科学 家 臭 臭 教授 发 明了 一 个 机 器 ， 不 用 打开 糖果 包装 ， 它 
就 能 立刻 告诉 你 里 面 有 没有 人 金 券 。 机 器 的 机 械 手 展 出 手 如 电 ， 一 抓 一 个 
准 儿 ， 不 会 漏 掉 哪 怕 藏 有 一 点 点 金子 的 任何 东西 。 目 前 看 来 ， 它 解决 了 


所 有 的 问题 。 
一 一 罗 尔 德 . 达尔 ,《 查 理 和 巧克力 工厂 》 


了 中 
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近 半 数 的 美国 人 都 拥有 智能 手机 。 智 能 手机 也 是 计算 机 ， 其 计算 能 力 比 几 十 年 前 
的 超级 计算 机 还 要 强 。 计 算 机 将 世界 上 的 信息 呈现 在 我 们 眼前 ， 也 帮 有 我 们 梳理 信息 。 
计算 机 让 人 们 可 以 彼此 交流 ,无 论 什么 身份 ,地 处 何方 。 计 算 机 能 执行 数量 巨大 的 运 
算 ， 从 模拟 宇宙 事件 到 调度 复杂 的 航线 。 计 算 机 可 以 识别 人 的 声音 、 面 孔 和 动作 。 计 
算 机 可 以 获悉 人 们 的 喜好 ， 并 据 此 推荐 图 书 、 音 乐 和 电影 。 在 不 远 的 将 来 ， 借 助 计算 
机 技术 ， 无 人 驾驶 的 汽车 将 随处 可 见 。 这 么 说 ， 计 算 机 简直 无 所 不 能 。 
































真是 这 样 吗 ? 在 这 本 书 里 , 我 们 将 探讨 许多 计算 问题 ,其 中 一 部 分 可 能 永远 都 无 
法 用 简单 的 计算 得 到 答案 。 试 着 解答 它们 是 计算 机 科学 ， 乃 至 整个 数学 和 科学 领域 最 
重要 的 挑战 。 人 们 给 这 些 问 题 起 了 一 个 有 些 奇 怪 的 名 字 : P/NP 问题 。 


























P/NP 是 克 雷 数学 研究 所 公布 的 7 个 千 祠 年 数学 难题 之 一 ,该 研究 所 为 求解 这 道 难 
题 设立 了 百 万 美元 的 奖金 。 不 过 ，P/NP 问题 的 意义 远 不 止 于 此 。 








P 指 的 是 用 计算 机 能 很 快 求解 的 问题 , NP 指 的 是 我 们 想 找到 最 优 解 的 问题 。 如 果 
P = NP ， 那 么 我 们 将 很 容易 找到 任意 给 定 问 题 的 解 。P = NP 意味 着 我 们 所 了 解 的 社 
会 将 发 生 巨 变 ， 医学 、 科 学 、 娱 乐 和 人 类 社会 一 切 任务 的 自动 化 程度 都 将 立即 发 生 质 
的 飞跃。 

相反 ,如果 P#NP ， 那 么 总 会 有 部 分 问题 无 法 迅速 地 被 解决 。 那 也 没有 关系 ， 
为 我 们 可 以 根据 具体 情况 研发 出 某 些 技术 来 解决 这 些 问 题 。P NP 意味 着 不 可 能 用 自 
动 化 的 方法 解决 所 有 问题 ,然而 ,知道 哪些 工具 不 好 用 也 有 助 于 人 们 找到 更 好 用 的 工具 。 














2008 年 8 月 ,《ACM 通讯 》 的 主编 英 舍 : 瓦 迪 约 我 写 一 篇 关于 P/NP 问题 的 文章 。 
ACM (美国 计算 机 协会 ) 是 一 个 为 计算 机 研究 学 者 和 从 业 人 员 服 务 的 重要 社团 ， 
《ACM 通讯 》 则 是 该 协会 刊登 文章 的 主要 杂志 。 






































2 可 能 与 不 可 能 的 边界 : P/NP 问题 趣 史 




















一 开始 我 想 把 写 稿 的 事 推 给 另 一 位 计算 机 科学 家 , 但 后 来 我 还 是 答应 了 。 当 时 莫 
舍 是 这 人 么 劝说 我 的 :“ 如 果 那 帮 物 理学 家 可 以 写 关 于 弦 理论 的 畅销 文章 ( 和 图 书 )， 那 
我 们 也 可 以 向 公众 解释 计算 复杂 度 理论 目前 的 进展 ， 我 希望 如 此 。” 于 是 我 写 了 一 篇 
文章 ， 该 文章 以 《ACM 通讯 》 的 读者 为 主要 受众 ， 不仅 介 绍 了 P/NP 问题 的 现状 ( 基 
本 可 以 概括 为 “悬而未决 ")， 也 讲 了 一 些 人 们 在 处 理 困 难 问 题 时 积累 的 技巧 。“P/NP 
问题 的 现状 ”( The Status of the P versus NP Problem ) 发 表 在 2009 年 9 月 的 《ACM iÑ 
讯 》 上 ， 它 很 快 就 成 为 该 刊物 创刊 以 来 下 载 次 数 最 多 的 文章 。 











关于 PNP 问题 ， 我 觉得 还 有 很 多 故事 可 讲 ， 而 那 篇 文章 的 大 受 欢 迎 ， 似 乎 表明 
是 时 候 面向 更 广 的 受众 〈 而 不 仅 是 科学 家 们 ) 来 讲述 这 些 故 事 了 。 























我 将 那 篇 短文 作为 本 书 的 框架 结构 ， 将 原来 文章 的 各 个 部 分 扩展 为 现在 的 章节 。 
我 还 受到 了 史蒂芬 霍金 的 《时 间 简 史 》 的 启发 : OBSS HE A ARURES, 
采用 生动 的 例子 和 故事 来 解释 物理 。 我 试图 以 同样 的 方式 来 讲解 P/NP 问题 ， 借 此 探 
讨 P/NP 问题 的 本 质 和 重要 意义 。 


























本 书 没有 给 出 PNP 问题 的 正式 定义 , 有 很 多 教科 书 和 网 站 都 详细 论述 了 P 了 和 NP 
的 定义 及 技术 结论 。 本 书 旨 在 让 你 对 计算 科学 的 潜能 和 局 限 性 有 更 多 的 了 解 ， 这 非常 
有 好 处 ， 毕 竞 计算 机 如 今 已 成 为 人 类 生活 不 可 或 缺 的 部 分 了 。 





向 P 和 NP 进发 吧 ! 
兰 斯 * 福特 诺 
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首先 感谢 Moshe Vardi, Afix TE, fbtiiedU Ie CACMBTU) Zi E 
的 “P/NP 问题 的 现状 ”一 文 的 编辑 。 这 篇 文章 受 欢 迎 的 程度 让 我 萌发 了 把 它 扩展 成 一 
本 科普 书 的 念头 。 








跟 我 一 块 写 博客 的 Bill Gasarch 不 断 鼓 励 我 ,并 仔细 审阅 了 全 书 各 章 的 初稿 Alana 
Lidawer 和 John、Jim， 以 及 Chris Purtilo 也 阅读 了 全 书 的 初稿 ， 并 提出 了 许多 宝贵 意 
见 。KuanLing Chen, Josh Grochow, Ralph Hansen, Adam Kalinich, David Pennock 
和 Rahul Santhanam 分 别 对 本 书 的 部 分 章节 提出 了 许多 宝贵 的 意见 。 





Manuel Blum, Steve Cook, David Johnson, Leonid Levin 和 Albert Meyer 分 别 以 
其 个 人 独到 的 视角 向 我 讲述 了 P/NP 问题 的 早期 历史 。Alexander Razborov 对 俄罗斯 历 
史 的 介绍 对 我 帮助 很 大 。 

















这 本 书 的 写作 离 不 开 我 的 生活 轿子。 作为 计算 机 科学 家 , 我 在 工作 和 生活 中 会 与 
其 他 研究 人 员 、 学 生 ， 以 及 数 不 清 的 人 交流 ， 这 种 交流 也 让 我 受益 菲 浅 。 在 此 特别 感 
谢 加 州 大 学 伯克利 分 校 、 麻 省 理工 学 院 、 芝 加 哥 大 学 、 阿 姆 斯 特 丹 的 数学 与 计算 机 科 
学 中 心 、NEC 研究 院 、 丰 田 工业 大 学 芝加哥 分 校 以 及 西北 大 学 的 同行 们 ， 与 他 们 真 梦 
而 友好 的 讨论 让 我 获 益 良 多 。 






































另外 ， 我 还 要 特别 感谢 两 个 人 ， 他 们 对 我 早年 PNP 问题 观念 的 形成 影响 很 大 : 
Juris Hartmanis， 我 在 康 奈 尔 大 学 读本 科 期 间 首 次 从 他 这 里 接触 到 了 P 和 NP， 还 有 
Michael Sipser, 他 是 我 在 加 州 大 学 伯克利 分 校 和 麻 省 理工 学 院 的 博士 学 位 指导 老师 和 
好 朋友 。 
































在 为 第 6 章 的 地 图 填 色 问题 寻找 例子 时 ,我 在 网 上 寻求 了 帮助 ,感谢 那些 做 出 回 
应 的 人 : Chris Bogart, HsienChih Chang, Pálvólgyi Dömötör, David Eppstein, Lukasz 




















2 可 能 与 不 可 能 的 边界 : P/NP 问题 趣 史 


Grabowski、Gil Kalai、Charles Martel 以 及 Derrick Stolee。 


写作 期 间 ， 我 在 西北 大 学 的 Robert R. McCormick 工程 与 应 用 科学 学 院 担 任 电 子 
工程 和 计算 机 科学 教授 。 西 北大 学 十 分 鼓励 向 公众 传播 知识 的 著 书 活动 。 我 充分 利用 
了 教 职 的 特权 ， 尤其 是 利用 了 学 校 图 书馆 丰富 的 资源 ,包括 纸 质 文献 和 电子 文献 。 西 
北大 学 的 教 职 工 是 最 棱 的 ， 我 的 行政 助理 Marjorie Reyes 对 我 帮助 同样 很 大 。 




















普林斯顿 大 学 出 版 社 的 编辑 Vickie Kearn 为 我 提供 了 悉心 的 指导 ， 并 在 著 书 的 各 
个 阶段 仔细 审阅 了 手稿 , 让 这 本 书 变 得 更 好 。 我 还 想 感 谢 Vickie 的 助手 Quinn Fusting, 
以 及 出 版 社 的 全 体 工 作 人 员 。 





























最 大 的 感谢 留 给 我 的 家 人 : 妻子 Marcy、 两 个 女儿 Annie 和 Molly， 感 谢 她 们 对 
我 的 爱 与 鼓励 。 
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第 1 章 金 券 /1 


维 露 卡 的 父亲 索 尔 特 先生 是 个 富商 ， 他 决定 买 光 他 能 找到 的 巧 克 
力 。 这 还 不 够 ， 就 算 有 堆积 如 山 的 巧克力 ， 要 从 中 找到 小 小 的 金 券 也 
很 困难 。 


1.1 划分 的 难题 /3 
12 手 //4 

1.3. P/NP 问题 //5 
1.4 找到 金 券 /6 
15 ”漫漫 长 途 //7 
1.6 ”划分 难题 的 解 //8 

















第 2 章 美妙 的 世界 /10 


“不 完全 准确 ,” 医 生 说 ,“ 没 错 ， 厄 巴 纳 算法 帮 人 们 战胜 了 癌 魔 ， 
治愈 了 艾滋 病 和 糖尿 病 。 可 是 ， 我 们 还 不 知道 如 何 应 对 普通 感冒 。” 


2.1 厄 巴 纳 算法 //10 

2.2 计算 机 1， 癌症 07 13 
2.3 ”棒球 比赛 // 14 

24 奥 卡 姆 剃刀 /17 

25 创造 力 的 自动 化 /21 

2.6 终极 侦探 // 22 

2.7 美妙 世界 的 阴暗 面 // 23 
2.8 回 到 现实 / 24 
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第 3 章 PR 和 NP/25 


1852 年 ， 南 非 数学 家 弗朗西斯 格 思 里 在 为 英国 各 那 的 地 图 填 色 
时 ， 猜 想 是 否 只 用 四 种 颜色 ， 就 足够 让 所 有 地 图 上 每 两 个 接壤 的 地 区 
有 不 同 的 颜色 。 
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NP 中 最 难 的 问题 /44 


高 德 纳 对 这 个 民选 结果 不 太 满 意 ， 但 也 没有 觉得 它 差 到 让 人 活 不 
下 去 的 地 步 。 他 本 人 特别 想 要 找 一 个 英文 词 ， 既 能 捕捉 “困难 的 搜索 
问题 ”这 个 直观 的 意象 ， 又 要 琅琅 上 口 ， 便 于 向 大 众 普 及 。 


4.1 第 一 个 NP 完全 问题 / 44 
42 21 个 问题 /47 

43 起 个 好 名 字 有 那么 重要 吗 / 49 
44 ”超越 卡 普 的 工作 // 51 
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P 和 NP 诞 生前 的 历史 /62 

图 灵 在 1936 年 就 指出 ， 图 灵机 并 不 是 什么 都 能 计算 。 最 著名 的 例 
子 是 停机 问题 ， 即 没有 计算 机 能 通过 查看 一 段 代码 就 知道 自己 是 会 永 
远 执行 下 去 还 是 会 最 终 停止 。 
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52 东方 /68 
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处 理 困难 的 问题 /76 
有 时 候 一 个 问题 天 生 排 斥 任 何 可 能 解决 它 的 方法 ， 对 此 你 能 做 的 
只 有 放弃 ， 然 后 去 干 点 别 的 。 
61 H/T 
62 ”启发 式 方法 //78 
63 ”搜索 小 规模 的 解 // 83 
64 近似 计算 方法 // 85 
6.5 解决 一 个 不 同 的 问题 / 90 
6.6 ”接受 现实 // 92 


6.7 ”总结 /1/92 


WERA P z NP /94 

2010 年 8 月 6 日 ， 患 普 实 验 室 的 科学 家 维 纳 里 . 德 奥 拉 利 卡 向 22 位 
顶尖 的 理论 计算 机 科学 家 发 送 了 他 写 的 论文 ,题目 简洁 有 力 :“P NP ”。 
7. ”骗子 悖 论 // 95 
72 电路 /97 
7.3 证 明 P#NP 时 常 犯 的 错误 / 102 


74 现状 /104 

















秘密 /106 


每 个 人 都 有 秘密 ， 从 密码 到 电子 邮件 ， 我 们 都 有 不 想 让 别人 看 到 
的 东西 。 了 =NP 意味 着 菜 些 NP 问 题 拥 有 不 为 人 知 的 秘密 ， 无 法 很 快 找 


到 它 的 答案 。 
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量子 /123 
即使 有 极 小 部 分 的 量子 和 外 界 环境 发 生 轻 微 作 用 而 丧失 了 纠缠 
态 ， 从 另 一 头 出 现 的 我 就 很 可 能 被 毁 形 ， 甚 至 变 成 一 团 死 肉 。 
9.1 量子 录像 机 // 123 
9.20 ”量子 密码 学 // 127 
9.3 ”量子 隐形 传输 // 128 
9.4 量子 的 未 来 // 132 





未 来 /133 


我 本 人 对 P/NP 问 题 得 到 解决 的 前 景 持 悲观 态度 : 我 认为 PzNP ， 
而 且 此 生 都 看 不 到 它 的 证 明 。 


10.1 并 行 计算 / 133 

10.2 处理 大 数据 // 135 

103. 一切 事 物 的 网 络 化 // 136 
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一 个 糖果 三 老 板 决定 推出 一 个 活动 , 将 五 张 金 券 藏 到 巧克力 的 包装 里 ， 而 这 种 巧 
克 力 每 年 的 产量 数 以 千 万 计 。 找 到 金 券 的 人 将 得 到 一 次 珍贵 的 参观 工厂 的 机 会 。 





如 何 找到 这 些 金 券 ? 你 可 以 买 尽 可 能 多 的 巧克力 。 你 可 能 会 试 试用 磁铁 ， 可 异 
金 没 有 磁性 。 或 者 你 可 以 雇用 数 千 人 ， 让 他 们 每 人 筛 查 一 小 堆 巧克力 。 这 上 听 起 来 很 
傻 ， 但 是 小 姑娘 维 露 卡 … 索 尔 特 就 要 这 人 么 做 ， 因 为 她 特别 想得到 一 张 金 券 ， 去 参观 
威 利 . 旺 卡 的 巧克力 工厂 。 

维 露 卡 的 父亲 索 尔 特 先生 是 个 富商 ， 他 决定 买 光 他 能 找到 的 巧克力 。 这 还 不 够 ， 
就 算 有 堆积 如 山 的 巧克力 ,要 从 中 找到 小 小 的 金 券 也 很 困难 。 索 尔 特 先生 也 有 一 家 工 
厂 , 他 不 惜 动用 工厂 的 工人 , 终于 找到 了 一 张 金 券 。 他 对 记者 讲述 了 找到 金 券 的 过 程 : 






































我 是 做 花生 生意 的 ， 知 道 吧 ， 我 有 大 约 100 个 女工 为 我 璋 花生 ， 然 后 将 
它们 做 成 烤 花 生 米 和 脑 花生 米 。 她 们 整 天 就 坐 在 那儿 昼 花生 。 所 以 我 跟 她 们 
说 :“ 好 了 姑娘 们 ， 不 要 剥 花生 了 ， 大 家 开始 给 我 剥 这 些 破 糖 纸 吧 1” 然 后 她 
们 就 剥 。 我 让 工厂 的 每 一 个 工人 都 钱 足 了 劲 地 撕 掉 巧克力 的 包装 纸 ， 从 旱 干 
到 晚 。 

但 是 三 天 过 去 了 ， 我 们 还 是 没 走运 。 哦 ， 那 可 真 够 哈 ! 我 可 怜 的 小 维 露 
卡 越 来 越 暴躁， 每 次 我 一 回 家 地 就 朝 我 嘻 喷 :“ 我 的 金 券 在 哪儿 ? 我 要 我 的 
金 券 !” 她 撒 波 又 打滚 儿 ， 踢 腿 又 驯 嗪 ， 实 在 招 人 烦 ， 我 可 不 希望 看 到 我 的 
小 宝贝 这 么 不 高 兴 , 所 以 我 决定 一 直 找 , 不 找到 她 要 的 东西 葡 不 罢休。 终于 ， 
在 第 四 天 的 晚上 ， 一 个 女工 大 巴 :“ 我 找到 金 券 了 !” 然 后 我 说 :“ 把 它 给 我， 
快 !1” 她 给 了 我 ， 然 后 我 跑 着 回 家 把 它 交 给 了 亲爱 的 维 露 卡 ， 她 高 兴 得 合 不 
拢 嘴 。 我 们 家 又 变 得 其 乐 融融 了 。 











2 ， 可 能 与 不 可 能 的 边界 : PINP 问 题 趣 史 


和 索 尔 特 先生 一 样 ， 无 论 你 打算 怎么 找 那 张 金 券 ， 你 都 需要 大 量 时 间 、 人 金钱 , 或 
者 运气 。 也 许 有 一 天 ， 有 人 能 发 明 出 一 个 快速 找到 金 券 的 便宜 装置 ， 也 许 这 样 的 装置 
并 不 存在 。 




















然而 ，1000 万 对 于 今天 的 计算 机 来 说 只 是 很 小 的 数字 。 如 果 你 把 糖果 数字 化 ， 录 
入 一 个 数据 库 ， 现 在 的 电脑 只 用 不 到 一 秒 就 能 把 它 找 一 遍 。 虽 然 计算 机 比 人 快 得 多 ， 
但 它 面 对 的 问题 的 规模 也 比 在 糖果 里 找 金 券 大 得 多 。 











现在 最 大 的 电子 数据 集合 规模 有 多 大 ? 比如 ， 整 个 互联 网 ， 考 虑 到 所 有 视频 、 音 
频 、 电 子 邮件 及 其 他 一 切 ， 总 的 信息 量 差 不 多 有 1 000 000 000 000 000 000 字 节 ， 最 多 
相差 几 个 0。 一 个 字 节 大 致 对 应 键盘 上 的 一 个 字符 。 这 个 数 很 大 ,但 记 住 ， 计 算 机 也 
很 快 。 一般 的 笔记 本 电脑 每 秒 可 以 执行 1 万 亿 次 操作 ,这样 算 来 ,理论 上 只 需要 不 到 4 
个 月 就 能 搜 完整 个 互联 网 的 内 容 ， 前 提 是 你 能 把 整个 互联 网 装 到 你 电脑 的 内 存 里 。 
Google 每 时 每 刻 都 在 搜索 整个 互联 网 ， 它 使 用 了 几 十 万 台 快 速 的 计算 机 。 












































如 果 计 算 机 可 以 很 快 地 搜 遍 整个 互联 网 , 看 起 来 好 像 我 们 就 解决 了 这 个 找 金 券 问题 
的 电子 版 。 但 是 ， 计 算 机 不 仅 要 帮 人 们 搜索 已 有 的 数据 ， 还 要 搜索 问题 的 所 有 可 能 解 。 


























认识 一 下 可 怜 的 旅行 推销 员 Mary, 她 来 自 华盛顿 特区 , 为 美国 木 杰 集团 公司 工作 。 
她 需要 从 家 乡 旅 行 到 48 个 州 的 首府 ， 向 各 州 法 院 推销 木 析 。 木 楼 公司 为 了 削减 成 本 ， 
让 Mary 找 到 通过 所 有 城市 的 最 短路 径 。Mary 画 了 一 张 图 , 写 写 画 画 了 一 会 儿 , 制订 了 
一 个 不 错 的 路 线 。 









































差 旅 部 门 的 人 想 让 Mary 试 试 能 否 找到 另 一 条 路 线 ,把 路 程 缩短 到 11 000 英 里 以 下 。 
Mary 写 了 个 计算 机 程序 , 试图 穷 举 所 有 可 能 的 路 线 , 找 出 最 短 的 一 条 , 但 是 一 周 以 后 ， 
程序 还 没 跑 完 。Mary 坐 下 来 开始 算数 。 作 为 第 一 站 的 城市 有 48 种 选择 ， 然 后 从 剩 下 的 
47 个 城市 中 选 一 个 作为 第 二 站 ， 再 从 剩 下 的 46 个 城市 中 选 一 个 ， 以 此 类 推 。 可 能 的 路 
径 共 有 48 x 47x46x… x2x1 种 ， 也 就 是 下 面 这 个 62 位 数 ; 





















































12 413 915 592 536 072 670 862 289 047 373 375 038 521 486 354 677 760 000 000 000 


即使 计算 机 计算 一 条 路 线 的 时 间 等 于 光 通 过 最 小 的 原子 直径 的 时 间 ( 大约 
0.000 000 000 000 000 000 33 秒 )， 仍 然 需 要 十 亿 亿 亿 倍 于 宇宙 年 龄 的 时 间 才 能 算 完 。 
难怪 Mary 的 电脑 算 了 一 周 还 没有 完 。Mary 想 知道 有 没有 比 穷 举 更 好 的 方法 找到 最 佳 路 
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线 ， 就 像 在 所 有 可 能 行程 的 “巧克力 山 ” 里 面 刨 出 那 张 小 小 的 金 券 。 





总 距离 =11 126 英 里 ? 





图 1-1 旅行 推销 员 问 题 的 地 图 
这 就 是 本 书 最 基本 的 问题 : P/NP 问 题 。 其 中 的 一 个 实例 就 是 能 否 为 旅行 推销 员 找 
到 最 短路 径 。P 和 NP 自 有 其 十 分 专业 的 定义 ,但 是 把 它们 看 做 概念 比 看 做 数学 对 象 更 
好 。NP 是 存在 解 的 问题 的 集合 , P 则 是 能 很 快 找到 解 的 问题 的 集合 。P = NP 意味 着 我 
们 能 总 是 很 快 地 计算 出 任何 问题 的 解 , 当然 也 包括 找到 旅行 推销 员 的 最 短路 径 。 相反， 
Pz NP 意味 着 我 们 不 能 。 






























































1.1 划分 的 难题 


看 下 边 38 个 数字 : 





14 175, 15 055, 16 616, 17 495, 18 072, 19 390, 19 731, 22 161, 23 320, 
23 717, 26 343, 28 725, 29 127, 32 257, 40 020, 41 867, 43 155, 46 298, 
56 734, 57 176, 58 306, 61 848, 65 825, 66 042, 68 634, 69 189, 72 936, 
74 287, 74 537, 81 942, 82 027, 82 623, 82 802, 82 988, 90 467, 97 042, 
977 507, 99 564 




















CD 1 英里 约 合 1.609 千 米 。 一 一 编者 注 

















4, 可 能 与 不 可 能 的 边界 : P/NP 问 题 趣 史 











这 38 个 数字 之 和 为 2 000 000。 你 能 把 它们 平分 成 两 组 ， 每 组 19 个 数字 之 和 分 别 
为 1 000 000 吗 ? 你 可 以 使 用 计算 器 、 电 子 表格 或 写 一 个 计算 机 程序 。( 答案 在 本 章 
最 后 。) 
































不 那么 简单 ， 是 吧 ? 把 这 些 数 分 成 两 组 有 170 亿 种 方式 。 如 果 程 序 编 得 巧妙 ， 使 
用 当今 较 快 的 计算 机 能 够 找到 一 个 解 。 但 如 果 给 你 3800 个 数 ， 或 者 3800 万 个 数 呢 ? 短 
小 的 计算 机 程序 可 没 法 给 出 答案 了 ! 














这 只 是 个 无 意义 的 数学 谜 题 吗 ? 就 算 存 在 一 个 厉害 的 计算 机 程序 , 它 能 解决 这 个 
平分 数组 的 问题 (假设 有 解 )， 那 又 如 何 呢 ? 如 果 是 这 样 的 话 ， 我 们 能 用 这 个 程序 做 
更 多 的 事 。 这 个 程序 能 解决 所 有 的 问题 ， 包 括 旅行 推销 员 问 题 。 这 个 简短 的 难题 抓 住 
了 P/NP 问 题 的 本 质 : 一 个 程序 如 果 能 解决 这 个 难题 的 复杂 版 本 , 那么 它 也 能 解 出 任意 


问题 。 
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你 的 手 是 最 不 可 思议 的 工程 装置 ， 它 能 蕉 、 抓 和 指 ， 能 系 鞋 带 ， 能 射箭， 还 能 
弹 钢琴 、 拉 小 提琴 ， 能 变 戏 法 ， 能 驾驶 车 、 船 、 火 车 或 飞机 。 你 的 手 可 以 握 住 其 他 
人 的 手 ， 或 跟 他 们 玩 拇指 相 扑 。 手 可 以 比划 出 信号 语言 ， 也 能 通过 写字 或 打字 来 交 
流 。 手 可 以 轻 抚 ， 也 能 重 击 。 手 可 以 使 用 修理 钟表 的 精密 工具 ， 也 能 操作 链条 饥 。 
有 才华 的 人 的 双手 可 以 创造 艺术 杰作 , 写 出 音乐 或 诗歌 。 人 类 取得 的 几乎 所 有 成 就 ， 
都 离 不 开 双手 。 




















一 只 手 有 27 块 骨头 ，5 根 手指 ， 包 括 最 重要 的 拇指 。 手 具有 结构 复杂 的 神经 、 肌 
有 和 肌肉 ,这 些 都 包 右 在 富有 弹性 的 皮肤 里 。 然 而 ， 这 一 不 可 思议 的 装置 ， 自 然 造物 
的 杰作 ， 却 不 能 自己 做 事 ， 而 只 能 执行 人 脑 的 指令 。 死 人 的 手 平平 无 奇 , 做 不 了 任何 
事情 。 





























手 就 是 自然 的 硬件 , 硬件 本 身 不 能 做 什么 。 手 需要 软件 (也 就 是 大 脑 指 令 ) 来 控 
制 ， 软 件 告 诉 它 如 何 执 行 和 实现 大 脑 希望 它 做 的 事情 。 








松 内 容 子 是 华盛顿 大 学 的 机 带 人 学 教授 , 她 带领 科研 小 组 制作 了 一 个 解剖 学 上 下 
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确 无 误 的 机 械 手 ， 其 手指 有 和 人 类 手指 同样 的 动作 自由 度 。 理 论 上 她 的 机 械 手 可 以 完 
成 人 手 能 做 的 任何 事情 ， 但 实际 上 ， 它 只 能 完成 很 简单 的 任务 ， 因 为 写 一 个 计算 机 程 
序 来 全 方位 控制 松 冈 的 机 械 手 ,是 非常 困难 的 。 在 协调 多 块 肌肉 的 运动 时 ， 即 使 是 完 
成 最 简单 的 任务 ， 也 需要 很 复杂 的 代码 。 














然而 我 们 的 脑 就 能 控制 手 。 可 以 将 脑 看 做 一 个 性 能 强大 的 计算 机 ， 如 果 脑 能 控 秆 
手 去 系 鞋 带 或 是 创作 艺术 ,那么 计算 机 程序 也 一 定 能 。 








< 
c 











知道 这 样 的 程序 存在 并 不 意味 着 就 能 找到 它们 。 随 着 时 间 的 推移 ， 计 算 机 科学 家 
肯定 会 写 出 更 精深 的 程序 ， 松 内 的 机 械 手 将 能 执行 更 复杂 的 活动 。 这 肯定 是 一 个 精彩 
的 旅程 ， 但 也 可 能 进展 缓慢 、 举 步 维 艰 。 

















一 定 要 这 样 缓慢 吗 ? 想象 一 下 , 只 要 我 们 简单 描述 一 项 任务 , 马上 就 会 有 一 个 程序 
提供 相应 的 功能 ; 给 计算 机 输入 一 段 演示 人 如 何 打 结 的 电影 , 然后 它 立 刻 就 能 用 机 械 手 
重复 打 结 的 过 程 ;把 莎士比亚 全 集 录入 计算 机 ， 然 后 它 就 能 创作 一 部 新 的 “莎士比亚 ” 
戏剧 ; 只 要 我 们 能 认 出 某 个 东西 ,就 能 找到 它 。 这 些 梦 想 都 能 成 真一 一 前 提 是 P= NP 。 















































PNP 问 题 的 魅力 就 在 这 里 。 究竟 能 否 让 所 有 的 事 都 变 得 易如反掌 ? 还 是 说 , 有 些 事 
情 注定 就 没有 简单 的 解决 方法 ? 不 能 排除 这 种 可 能 性 。 无 论 如 何 , 我 们 并 不 指望 生活 会 
那么 简单 。 尽 管 我 们 并 不 认为 P= NP, (Ex ASSERITUR ADLESRAL TAS A BE Te DER 














13 ”P/NP 问 题 


PNP 问 题 讨论 的 是 以 上 所 述 的 所 有 问题 ， 以 及 许多 与 之 类 似 的 问题 。 它 们 归根 到 
底 都 是 在 问 : 我 们 搜索 大 量 可 能 性 的 速度 能 有 多 快 ? 我 们 找到 “ 金 券 ”( 即 最 佳 答案 ) 
的 过 程 能 变 得 多 容易 ? 





P/NP 问 题 是 库 尔 特 ' 哥 德 尔 在 1956 年 寄 给 约翰 : 13 - 诺 依 曼 的 一 封 信 中 首次 提出 
的 ， 哥 德尔 和 冯 : 诺 依 曼 都 是 20 世 纪 数 学 界 的 泰斗 。 这 封 信 后 来 不 幸 遗 失 ，20 世 纪 80 
年 代 又 被 找到 。P/NP 问 题 在 学 术 界 的 亮相 是 在 20 世 纪 70 年 代 初 ， 由 斯 蒂 芬 . 库 克 和 列 
昂 尼 德 . 莱 文 独立 提出 ， 当 时 两 位 所 在 的 国家 正在 冷战 。 之 后 理 查 德 . 卡 普 列 出 了 这 
个 领域 中 的 21 个 重要 难题 , 包括 前 面 提 到 的 旅行 推销 员 难 题 和 划分 难题 。 计 算 机 科学 
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家 从 卡 普 的 工作 开始 认识 到 P/NP 问 题 极 为 重要 , 由 此 计算 机 科学 研究 的 方向 发 生 了 戏 
剧 性 的 转变 。 如 今 , P/NP 问 题 的 关键 性 作用 已 经 不 仅 限于 计算 机 科学 领域 ,还 延伸 到 
其 他 许多 领域 ， 如 生物 学 、 医 学 、 经 济 学 和 物理 学 。 




















P/NP 问 题 已 成 为 所 有 数学 领域 最 难 的 开放 问题 之 一 。1994 年 安德鲁 怀 尔 斯 证 明 
了 费 马 大 定理 , 受 这 一 消息 的 鼓手， 克 雷 数学 研究 所 决定 举办 竞赛 ,攻克 他 们 认为 最 
为 重要 而 尚未 解决 的 数学 难题 。2000 年 ， 他 们 列 出 了 下 面 这 7 个 千 禧 年 难题 ， 并 为 每 
道 难题 的 攻破 设立 了 100 万 美元 的 奖金 。 











1. 贝 赫 和 斯 维 讷 通 - 戴 尔 猜 想 ( Birch and Swinnerton-Dyer conjecture ) 
2. 霍 奇 猜想 ( Hodge conjecture ) 

3. 纳 维 - 斯 托 克 斯 方程 (Navier-Stokes equations ) 

4. P/NP 问 题 (P versus NP ) 

5. 庞 加 莱 猜 想 (Poincare conjecture ) 

6. 黎 曼 猜想 ( Riemann hypothesis ) 

7. 杨 - 米 尔 斯 理论 (Yang-Mills theory ) 





























千 禧 年 难题 中 的 庞 加 莱 猜 想 已 于 2003 年 被 格 里 高 利 ， 佩 雷 尔 曼 解 决 , 但 他 拒绝 了 
100 万 美元 的 奖金 。 截 至 本 书写 作 时 其 他 6 个 难题 都 尚未 解决 。 








解决 PINP 问 题 就 能 拿 到 100 万 美元 ， 这 可 是 货真价实 的 金 券 啊 ! 




















更 妙 的 是 ,如果 你 能 证 明 P = NP ,那么 你 也 就 掌握 了 找到 金 券 的 秘诀 , 解决 其 余 
的 千 禧 年 难题 将 是 举 手 之 劳 。 也 就 是 说 , 证 明了 P= NP , 你 就 能 解决 6 道 千 禧 年 难题 ， 
并 得 到 600 万 美元 。 然 而 证 明 P= NP :k P + NP 可 没 那么 容易 。 一 心 想得到 600 万 美元 
的 人 最 好 去 玩 彩票 ， 那 样 把 握 更 大 一 些 。 











14 RIEZ 


有 时 候 我 们 能 够 找到 金 券 。 比 如 我 在 芝加哥 ， 想 开车 去 纽约 ， 往 车 载 GPS 里 输入 
地 址 , 一 两 分 钟 之 内 它 就 能 给 出 一 条 从 芝加哥 到 纽约 的 最 快 路 线 ， 然后 我 就 可 以 踏 上 
旅程 了 。 几 百 万 字 节 的 内 存 便 可 容纳 全 部 的 美国 街道 地 图 , 但 地 图 中 可 能 的 路 线 远 远 
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超过 几 百 万 。 从 芝加哥 到 纽约 所 有 可 能 的 行车 路 线 有 多 少 条 ? 不 开 错 方向 的 情况 下 ， 
保守 计算 可 得 出 的 路 线 数目 大 到 了 “不 可 思议 ”, 即 1 后 边 跟 63 个 0。GPS 根 本 没有 时 间 
检查 所 有 的 可 能 性 ， 但 还 是 能 找到 最 快 的 路 线 。 























旅行 时 间 有 一 个 有 趣 的 性 质 。 随 便 选 一 个 中 间 地 点 〈 比如 匹兹堡 )， 从 芝加哥 经 
过 匹 效 保 到 纽约 的 最 短路 线 ,一 定 是 芝加哥 到 匹兹堡 的 最 短路 线 ， 再 接 上 匹兹堡 到 纽 
约 的 最 短路 线 。 不 走 匹 效 堡 可 能 有 更 快 的 路 线 ， 但 是 芝加哥 到 纽约 的 最 短路 线 ， 绝 不 
会 比 从 芝加哥 经 过 匹兹堡 到 纽约 的 最 短路 线 还 要 长 。 








GPS 的 计算 机 程序 正 是 利用 了 这 个 性 质 ， 快 速 缩小 搜索 范围 并 找到 了 最 佳 路 线 。 
这 可 能 仍 需 要 检查 上 亿 条 路 线 ， 但 是 GPS 的 计算 机 处 理 器 完全 能 胜任 ， 毕 竟 这 个 数字 
比 “ 不 可 思议 ”小 多 了 。 




















找到 最 短路 径 并 没有 体现 P/NP 问 题 的 全 部 力量 。 最短 路径 问题 告诉 我 们 , 全 部 的 
可 能 性 数量 特别 大 , 但 这 并 不 总 意味 着 必须 遍历 所 有 的 可 能 性 才能 找到 答案 。P/NP 问 
TRKE, 是 不 是 对 于 任意 给 定 的 搜索 问题 , 我们 都 不 必 遍 历 所 有 的 可 能 性 就 能 找 
到 管 案 ? 






































1.5 漫漫 长 途 

















本 书 讲 的 是 P 和 NP 的 故事 。 什 么 是 P 和 NP? P/NP 描 述 的 是 哪 类 问题 ? 所 有 搜索 问 
题 中 最 难 的 问题 “NP 完全 问题 ”是 怎么 回 事 ? 这 些 问 题 如 何 影 响 P/NP 问 题 ? 








举 个 简单 的 例子 , Facebook 上 的 好 友 圈 子 ( BIBIT, clique) F, 最 大 的 包含 多 少 人 ? 
100 人 ,还 是 1000 人 ?即使 你 拥有 Facebook 的 全 部 数据 ， 这 个 问题 也 很 难 求解 。 求 解 
较 大 规模 团 问 题 的 困难 程度 ， 不 亚 于 任何 搜索 问题 。 














如 果 P= NP 会 怎么 样 ? 那么 我 们 将 迎 来 一 个 美好 的 世界 ,计算 所 有 的 事物 都 将 易 
如 反 掌 。 我 们 能 快速 地 了 解 一 切 ， 揭 开 世 界 上 所 有 事物 的 神秘 面纱 ， 从 治愈 绝症 到 洞 
悉 宇 宙 的 本 质 。 美 好 的 世界 也 有 它 灰暗 的 一 面 ， 人 们 将 丧失 隐私 、 丢 掉 工 作 ， 因 为 没 
有 什么 是 计算 机 不 能 知道 或 完成 的 。 























这 样 美好 的 世界 几乎 不 太 可 能 。 困 难 的 搜索 问题 仍 将 存在 ,我 们 想 要 其 至 需要 找 
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到 它们 的 答案 。 其 实 我 们 大 可 不 必 放 弃 。 计 算 机 科学 家 已 研发 出 许多 技术 ,包括 很 有 
可 能 对 许多 问题 奏效 的 启发 式 方法 ,以 及 能 给 出 接近 理想 解 的 近似 技术 。 





P 和 NP 问题 是 如 何 产 生 的 ?这 个 故事 发 生 在 世界 因 冷 战 被 割裂 的 那 段 日 子 ， 其 实 
可 以 把 它 分 成 两 个 故事 来 讲 。 有 关 高 性 能 计算 的 思路 和 问题 分 别 在 两 个 世界 独立 发 
展 ， 而 这 两 个 世界 的 研究 最 终 殊途同归 ， 从 而 产生 了 P/NP 问 题 。 

















从 哪里 着 手 证 明 Pz NP? 库 尔 特 ' 哥 德尔 证 明 数 学 不 能 解决 所 有 的 问题 。 能 和 否 用 
类 似 的 方法 ,证 明 存在 不 能 快速 解决 的 搜索 问题 ?为 了 分 析 问 题 的 复杂 度 ， 我 们 可 以 
把 计算 过 程 分 解 为 最 基本 的 单元 。 算 术 几 何 学 (数学 的 一 个 抽象 分 支 )， 为 人 们 能 在 
有 朝 一 日 解决 这 个 重要 的 问题 带 来 了 新 的 希望 。 但 我 们 距离 那 一 天 还 很 远 。 




















P « NP 会 带 来 什么 好 处 呢 ?” 它 能 帮助 我 们 保守 秘密 ， 产 生 看 上 去 真 随机 的 伪 随 
机 数 。 

















未 来 基于 量子 力学 的 计算 机 能 否 让 P/NP 问 题 变 得 无 足 轻 重 ? 不 太 可 能 , 不 过 量子 
计算 机 的 建成 将 解决 一 部 分 现在 计算 机 束手无策 的 问题 , 比如 大 数 的 因数 分 解 。 此外， 
量子 力学 也 会 透露 ?是 否 等 于 NP 的 玄机 。 























未 来 将 会 如 何 呢 ?我 们 仍 将 面临 计算 领域 的 巨大 挑战 。 人 们 如 何 与 互相 协作 处 理 
问题 的 计算 机 打交道 ?如何 分 析 每 天 产生 的 海量 数据 ? 所 有 事物 都 能 联网 , 世界 将 会 
怎样 ? 要 解决 这 些 问题 ，P/NP 问 题 只 会 变 得 更 为 关键 。 











L6 ”划分 难题 的 解 


以 下 38 个 数 


14 175, 15 055, 16 616, 17 495, 18 072, 19 390, 19 731, 22 161, 23 320, 
23 717, 26 343, 28 725, 29 127, 32 257, 40 020, 41 867, 43 155, 46 298, 
56 734, 57 176, 58 306, 61 848, 65 825, 66 042, 68 634, 69 189, 72 936, 
74 287, 74 537, 81 942, 82 027, 82 623, 82 802, 82 988, 90 467, 97 042, 
97 507, 99 564 


可 分 成 如 下 两 组 : 


15 055, 16 616, 19 390, 22 161, 26 343, 40 020, 41 867, 43 155, 46 298, 
57 176, 58 306, 65 825, 66 042, 69 189, 74 537, 81 942, 82 623, 82 988, 
90 467 


和 


14 175, 17 495, 18 072, 19 731, 23 320, 23 717, 28 725, 29 127, 32 257, 
56 734, 61 848, 68 634, 72 936, 74 287, 82 027, 82 802, 97 042, 97 507, 
99 564 





每 组 中 所 有 数字 之 和 都 是 1 000 000, 


a 第 2 章 b 
关 妙 的 世界 


假设 有 人 请 你 写 一 篇 关于 过 去 20 年 互联 网 带 来 的 社会 变革 的 论文 。 你 是 写 装 在 口 
袋 里 的 设备 让 人 们 能 够 随时 访问 所 有 公开 的 信息 ， 还 是 会 探讨 发 生 在 音乐 、 电 影 、 出 
版 和 新 闻 产业 的 巨大 变化 ?无 论 怎么 写 , 短 短 一 篇 论文 都 很 难 公允 地 描述 过 去 20 年 发 
生 的 变化 。 好 了 ， 再 想象 一 下 : 如 果 是 让 你 在 这 些 变 化 尚未 发 生 的 20 世 纪 90 年 代 写 这 
篇 论文 ， 你 又 会 对 未 来 做 出 怎样 的 预测 ? 












































如 果 P = NP 被 证 实 ， 即 我 们 掌握 了 一 种 对 所 有 NP 问题 都 有 效 的 快速 算法 ， 那 么 
社会 将 发 生 更 加 巨大 的 变化 ， 互 联网 看 起 来 只 是 历史 的 一 个 补充 说 明 。 不 光 不 可 能 描 
述 全 部 的 变化 ， 其 至 不 太 可 能 预测 新 技术 带 来 的 深远 影响 。 











为 了 能 让 读者 对 那个 美妙 的 世界 有 些许 认 知 ,现在 让 我 们 来 想象 一 下 发 现 解 决 NP 
问题 的 有 效 算法 几 年 之 后 会 发 生 什么 。 让 我 们 一 起 跳 到 2026 年 , 去 看 看 一 个 P=NP 被 
证 实 的 世界 一 一 当然 ， 这 个 世界 是 科幻 的 。 首 先 ， 咱 们 来 看 看 这 个 世界 是 怎么 打造 出 
来 的 o 
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2016 年 ， 捷 克 数 学 家 米 莱 娜 由 维尔 用 邮件 转发 了 一 个 她 认为 理论 上 能 有 效 解决 
NP 问题 的 算法 。 计算机 科学 和 数学 界 经 过 仔细 验证 , 一 致 认为 米 莱 娜 所 言 不 虚 , 算法 
确实 解决 了 伟大 的 PINP 问 题 。 米 莱 娜 将 算法 发 表 成 论文 ,文章 本 身 的 名 字 很 低调 ， 叫 
做 “ 论 一 个 库 克 没有 解决 的 问题 ”( On an Open Problem of Cook )， 而 《纽约 时 报 》 介 
绍 文章 的 标题 更 为 直 白 ， 恰 如 其 分 地 表明 了 它 的 价值 :“P=NP ”。 
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2018 年 ， 米 莱 娜 成 为 第 一 个 获得 数学 领域 最 高 荣誉 (GERAK ) 的 女性 。 一 年 后 
克 雷 数学 研究 所 奖 给 米 莱 娜 一 张 价值 100 万 美元 的 支票 。 她 成 为 继 格 里 高 利 * 佩 雷 尔 
曼 之 后 第 二 个 成 功 解决 千 禧 年 数学 难题 的 人 。 不 像 佩 雷 尔 曼 ， 她 高 兴 地 收 下 了 奖金 ， 
并 将 其 中 一 部 分 (数额 未 知 ) 捐 给 了 故乡 布拉格 的 大 学 作为 奖学金 。 
































虽然 米 莱 娜 的 算法 在 理论 上 是 一 个 突破 , 但 因为 实际 执行 时 间 过 长 而 缺乏 实用 价 
值 。2017 年 ， 俄 罗斯 计算 机 科学 家 明 斯 友 ' 波 洛 夫 采用 一 种 巧妙 的 方法 改良 了 米 莱 娜 
的 算法 ， 从 而 大 幅 改 进 了 算法 的 执行 效率 ， 然 而 还 是 不 够 实用 。 





















































一 年 后 在 中 国 ,清华 大 学 的 一 群 本 科 生 仔细 优化 了 明 斯 克 的 代码 ， 在 当时 世界 上 
最 快 的 超级 计算 机 上 运行 它 。 他 们 在 几 天 之 内 就 解决 了 较 大 规模 的 团 问题 和 其 他 几 个 
常见 的 NP 问 题 。 清 华 大 学 开始 与 波音 、 戴 姆 勒 -奔驰 等 工业 巨头 签约 ， 帮 助 这些 公 司 
解决 一 些 棘手 的 优化 问题 。 他 们 帮助 波音 为 新 797 客 机 设计 出 了 更 好 的 机 如 ， 使 得 客 
机 能 直接 从 伦敦 飞 到 悉尼 。 






































史 蒂 夫 ' 弗兰克 是 伊利 诺 伊 大 学 的 博士 生 ， 此 时 在 清华 做 一 学 期 的 访问 学 者 ， 他 
有 幸 参 与 了 项 目的 研究 工作 。 回 到 伊利 诺 伊 州 的 厄 巴 纳 后 ， 他 向 导师 诉苦 ， 无 论 他 们 
如 何 优化 ， 还 是 要 花 几 天 时 间 才 能 解决 一 个 中 等 规模 的 NP 问题 。 








“如 果 你 遇 到 灯 神 ， 它 能 满足 你 一 个 愿望 ， 你 会 许 什么 愿 ?” ”导师 说 。 
“不 知道 。 史 蒂 夫 回答 。 
“让 它 给 你 一 个 能 满足 你 所 有 愿望 的 灯 神 !1” 


史 蒂 夫 脑 中 一 亮 。 他 知道 一 定 存在 一 个 能 更 好 解决 团 问题 的 算法 ， 而 他 自己 想 不 
出 这 个 算法 。 但 是 他 遇 到 了 灯 神 一 一 清华 的 代码 ， 他 可 以 用 很 快 的 速度 搜索 指数 级 数 
量 的 可 能 算法 。 所 以 他 基于 清华 的 例 程 写 了 一 个 搜索 更 好 的 NP 问 题 算法 的 程序 。 他 获 
准 可 以 使 用 位 于 伊利 诺 伊 大 学 的 国家 超级 计算 应 用 中 心 (NCSA ) 的 计算 资源 。 经 过 
几 周 的 计算 , 他 的 工作 初 见 成 效 。 他 找到 了 一 个 比 清华 的 算法 性 能 高 5% 的 算法 。 这 
结果 发 篇 论文 绰绰有余 ， 但 不 会 产生 情 动 效应 。 


















































他 的 导师 淡淡 地 说 :“ 用 新 算法 再 试 一 次 。 





于 是 史 带 夫 用 他 的 新 算法 找到 了 一 个 更 快 的 解决 NP 问题 的 算法 。 几 周 后 他 获得 了 
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20% 的 性 能 提升 。 


但 他 的 导师 还 不 满意 :“ 再 试 一 次 。 








史 蒂 夫 这 样 回答 :“ 我 为 什么 不 编 个 程序 让 计算 机 自动 使 用 找到 的 算法 来 查找 更 
好 的 算法 呢 ? ” 














导师 的 目光 变 得 异样 起 来 ， 仿 佛 在 说 你 终于 开 窜 了 ， 又 仿佛 在 说 ， 这 么 明显 的 事 
你 怎么 现在 才 想到 。 








史 蒂 夫 回 到 办 公 室 ， 开始 写 一 个 算法 ,让 计算 机 能 自动 利用 搜索 到 的 更 快 的 算法 
去 查找 比 当前 算法 更 快 的 算法 ， 这 样 一 直 找 下 去 ， 直 到 性 能 无 法 提升 为 止 。 史 蒂 夫 的 
一 个 同事 问 他 是 和 否 担心 天 网 效应 。 





























“天 网 是 啥 ? ” 


“ 当 计算 机 变 得 足够 聪明 ， 有 了 自我 意识 ， 它 就 会 接管 世界 ， 就 像 《终结 者 》 系 
列 电影 里 的 超级 计算 机 “天 网 ”一 样 。 





“不 ， 只 是 计算 机 代码 而 已 ， 不 用 担心 。 
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史 带 夫 写 好 了 代码 ， 最 后 一 次 在 NCSA 的 超级 计算 机 上 运行 它 。 随 着 迭代 次 数 的 
增加 ,由 计算 机 自动 生成 的 求解 NP 问题 的 算法 性 能 变 得 越 来 越 好 , 最 后 在 停止 时 , Æ 
成 了 一 个 有 4200 万 行 机 器 码 的 让 人 费解 的 程序 。 它 求解 NP 问题 的 速度 ， 那 是 相当 快 。 
(顺便 说 一 名 ,计算 机 依然 没有 自我 意识 。) 某 高 校 出 版 社 将 这 个 算法 自豪 地 称 为 “ 厄 
巴 纳 算法 ”， 后 来 这 个 名 字 被 保留 了 下 来 。 











伊利 诺 伊 大 学 的 数学 家 们 开始 率先 使 用 厄 巴 纳 算 法 , 用 它 来 证 明 剩 下 的 千 禧 年 数 
学 难题 。 证 明 过 程 是 计算 机 生成 的 ， 复 杂 到 人 类 几乎 无 法 理解 。 克 雷 数学 研究 所 很 快 
发 表 声 明 ,， 不 再 接受 基于 米 莱 娜 ， 帕 维尔 发 现 的 百 万 美元 算法 衍生 出 来 的 任何 算法 的 
数学 证 明 。 












































许多 试图 以 许可 证 和 买 断 方式 获得 厄 巴 纳 算法 的 公司 都 陷入 了 诉讼 泥潭 ， 因 为 与 
算法 有 关 的 各 方 一 一 资助 米 莱 娜 研究 的 捷克 政府 、 史 带 夫 . 弗兰克 、 史 带 夫 的 导师 以 
及 NCSA， 都 主张 自己 对 厄 巴 纳 算法 的 所 有 权 。 
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世界 贸易 组 织 在 认识 到 该 算法 的 重大 意义 后 ， 要 求 公 开 厄 巴 纳 算法 ， 供 全 人 类 志 
同 享 用 ， 相 关 各 方 将 得 到 合理 的 补偿 ， 并 成 立 专门 委员 会 落实 。2019 年 10 月 23 日 , 厄 
巴 纳 算法 对 所 有 人 公开 了 。 
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从 此 ， 世 界 发 生 了 一 系列 戏剧 性 的 变化 …… 


22 计算 机 1， 癌症 0 





海伦 的 医生 走 进 检查 室 ， 关 上 身后 的 门 ， 说 :“ 我 有 个 坏 消息 ， 你 患 有 胰腺 瘤 。 





海伦 倒 抽 一 口 冷气 。 她 才 43 岁 , 家 里 有 三 个 孩子 , 最 大 的 15 岁 , 最 小 的 才 6 岁 。“ 你 
怎么 可 能 知道 ， 我 不 过 验 了 个 血 。” 




















“我 们 现在 只 需要 得 到 血液 中 的 标记 物 和 DNA， 就 可 以 判断 你 是 否 患 有 癌症 ， 是 
哪 种 癌症 ， 以 及 癌变 的 程度 。 如 果 你 坚持 ,我 们 可 以 做 活检 ,但 是 没 必要 冒 这 个 险 ， 
现 有 的 检查 已 经 足够 精确 了 。 








“我 的 表姐 在 8 年 前 被 诊断 出 胰腺 癌 , 那 会 儿 是 2018 年 。 当 时 这 病 没 什么 治疗 措施 ， 
儿 个 月 后 她 就 过 世 了 。” 








“幸好 医学 在 过 去 十 年 里 有 了 很 大 的 进步 。 我 们 意识 到 适合 所 有 人 的 抗 瘤 方法 疗 
效 有 限 ， 人 们 需要 针对 个 体 的 治疗 方案 , 就 是 先 鉴 别 出 某 个 人 的 正常 DNA 和 癌 细 胞 的 
突变 DNA， 然后 制造 出 特定 的 蛋白 质 ， 其 折 炙 方式 不 仅 能 有 效 地 饿 死 癌 细胞 ， 而 且 对 
正常 细胞 没有 任何 影响 。 死 亡 的 痛 细 胞 会 被 排出 体外 。” 





“ 听 起 来 会 很 贵 。” 海伦 评论 道 。 


“化 疗 才 贵 呢 ， 这 种 疗法 的 成 本 只 有 几 干 美元， 将 来 还 会 更 便宜 。 大 部 分 费用 都 
可 以 由 你 的 医疗 保险 支付 。 








KRET! 过 去 十 年 究竟 发 生 了 什么 ， 让 检验 和 治疗 变 得 如 此 简便 ? ” 


“这 些 想法 很 早 就 有 了 ， 但 在 过 去 ， 即 使 是 世界 上 最 快 的 计算 机 在 解决 DNA 密 码 
方面 也 显得 太 慢 ， 所 以 一 直 没有 什么 突破 。 厄 巴 纳 算法 的 出 现 改变 了 这 种 状况 ， 过 去 
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几 年 里 我 们 取得 了 难以 置信 的 进步 。 通 常 一 项 新 技术 出 来 后 ,我 们 会 做 很 多 年 实验 才 
会 投入 临床 使 用 , 但 是 这 种 疗法 的 初期 测试 太 成 功 了 ,以 至 于 FDA 觉 得 不 立即 批准 投 
入 使 用 都 不 道德 ， 毕 竞 有 那么 多 的 癌症 患者 ， 他 们 等 不 起 。” 








“什么 时 候 开始 治疗 ? ”海伦 间 。 





“开始 ? 我 们 已 经 用 抽 的 血 做 完了 分 析 ， 这 是 你 的 处 方 。 








医生 递 给 海伦 的 不 是 一 张 纸 , 而 是 一 个 U 盘 。“ 这 里 面 有 治疗 你 的 癌症 的 蛋白 质 的 
编码 信息 。 把 它 带 到 药房 ， 让 他 们 为 你 制作 药片 。 一 天 一 片 ， 连 吃 两 周 ,你 体内 的 癌 
细胞 就 清扫 干净 了 ,没有 任何 副作用 。 但 是 要 注意 ， 这 个 处 方 只 对 你 起 作用 ， 其 他 人 
的 DNA 不 同 ， 如 果 吃 了 你 的 药片 ， 可 能 会 产生 严重 的 后 果 ， 甚 至 是 致命 的 。 

















“没有 副作用 ? 头发 不 会 掉 光 ? 没有 恶心 想 叶 的 感觉 ? 癌症 及 早 发 现 的 话 只 要 服 
几 片 药 就 好 了 ， 跟 治 感冒 一 样 所 有 这 一 切 都 得 益 于 一 个 算法 ? ” 

“不 完全 准确 ,” 医 生 说 ,“ 没 错 ， 厄 巴 纳 算法 帮 人 们 战胜 了 癌 魔 ， 治 愈 了 艾滋 病 
和 糖尿 病 。 可 是 ， 我 们 还 不 知道 如 何 应 对 普通 感冒 。” 





2.3 ”棒球 比赛 


“真是 打 棒球 的 好 天 气 !” 兰 迪 对 他 12 岁 的 女儿 凯特 说 , 这 是 他 第 一 次 带 女 儿 到 圣 路 
易 斯 看 棒球 比赛 。 圣路易斯 红 稚 队 主 场 对 战 密尔沃基 酿酒 人 , 这 场 2026 赛 季 末 的 夺冠 赛 
扣人心弦 。 兰 迪 感叹 棒球 运动 和 他 小 时 候 相 比 变化 不 少 。 这 项 运动 在 科技 的 使 用 上 曾经 
是 那么 地 原始 ， 甚 至 连 计 时 装置 都 不 用 ， 而 如 今 它 同 样 受到 了 厄 巴 纳 算法 的 巨大 影响 。 



































首先 当然 是 棒球 赛程 安排 上 的 变化 。 直 到 2004 年 ， 棒 球 大 联盟 (Major League 
Baseball ) 的 赛程 都 是 由 享 利 和 堆 莉 …， 斯蒂芬 森 夫 妇 来 安排 的 ， 这 对 夫妻 档 安排 赛程 
的 依据 是 几 条 简单 的 规则 ， 例 如 每 个 队 主场 和 客场 的 比赛 数 最 好 大 致 相等 ， 还 会 照顾 
某 些 地 方 的 偏好 ,如 波士顿 的 球迷 希望 把 波士顿 红 袜 队 的 一 次 主场 比赛 安排 在 四 月 中 
旬 爱 国 者 日 的 白天 ， 因 为 波士顿 马拉松 赛 的 参赛 人 员 会 在 那天 从 球场 旁边 经 过 。2005 
年 棒球 大 联盟 与 匹 效 堡 的 赛事 筹划 集团 (Sports Scheduling Group ) 签订 了 合作 协议 ， 
因为 这 家 公司 知道 如 何 避 免 两 支队 伍 在 连续 的 几 周 内 多 次 交锋 。 众 所 周知 ， 暴 雨天 气 
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无 法 进行 室外 棒球 赛 , 但 赛事 筹划 集团 在 安排 完事 时 从 不 考虑 下 雨 的 因素 ,原因 很 简 
单 ， 没 办 法 在 开赛 前 的 12 月 份 预 测 整 个 赛季 的 天 气 状况 。 当 然 , 那 是 厄 巴 纳 算法 出 现 
之 前 的 事情 了 。 


























在 算法 的 帮助 下 ， 人 类 的 天 气 预 测 技术 取得 了 不 可 思议 的 进步 ， 可 以 提前 一 年 准 
确 预测 温度 、 风 力 、 云 量 和 降水 。 类 似 的 算法 可 以 做 到 准确 预测 风暴 、 龙 卷 风 和 飓风 ， 
让 人 们 有 充足 的 准备 和 撤离 时 间 。 新 的 天 气 预测 技术 同样 改变 了 人 们 的 日 常生 活 。 学 
校 会 对 未 来 下 雪 的 日 子 提 前 做 准备 。 承 办 户外 婚礼 的 教堂 会 根据 未 来 婚期 的 天 气 状 况 
向 新 人 收取 不 同 的 费用 , 想 在 好 天 气 结婚 的 要 多 交 钱 ， 愿意 在 炎热 、 潮 湿 或 下 雨天 举 
行 露天 婚礼 的 则 可 以 享受 折扣 。 大 多 数 人 都 想 在 好 天 气 看 棒球 赛 ， 所 以 如 果 底 特 律 会 
下 雨 或 者 阴 天 的 话 ， 完 全 可 以 把 比赛 安排 到 明 尼 阿 波 利 斯 去 ， 那 里 将 艳阳 高 照 。 

































































赛场 和 电视 机 前 的 观众 都 想 看 到 高 质量 的 比赛 , 尤其 是 临近 赛季 末尾 时 优秀 球 队 
之 间 的 激烈 比拼 。 兰 迪 小 时 候 ， 判 断 哪 支 球 队 会 说 没有 科学 的 方法 ， 基 本 靠 猜 。 而 新 
的 预测 工具 料 事 如 神 ， 能 提前 告诉 人 们 哪些 球 队 将 进入 9 月 份 的 冠军 争夺 赛 。 计 算 机 
预测 胜 场 也 并 非 完 全 准确 。 棒 球 运动 具有 随机 性 ， 每 个 赛季 的 实际 战局 都 会 与 预测 有 
那么 几 场 的 出 入。 然而 算法 的 模型 仍 能 以 极 高 的 准确 率 预 测 哪些 球 队 会 在 赛季 末尾 名 
列 前 茅 。 那 些 没 被 预测 为 夺冠 热门 的 球 队 的 球迷 们 每 年 都 会 抱怨 计算 机 算 错 了 ， 然 而 
计算 机 通常 是 对 的 ， 唯 一 的 一 次 预测 失败 ， 被 人 们 津津 乐 道 。 



































棒球 产业 的 大 享 们 想 用 更 好 的 方式 安排 比赛 , 目标 之 一 是 让 每 个 人 都 能 在 最 好 的 
天 气 看 到 强 队 之 间 的 火拼 ， 当 然 还 有 更 实际 的 成 本 控制 方面 的 诉求 ， 比 如 尽 可 能 缩短 
每 个 团队 花 在 路 上 的 总 时 间 。15 年 前 , 根本 不 可 能 将 很 多 方面 纳入 考虑 ， 那 会 使 需要 
检验 的 计划 规模 庞大 得 难以 处 理 。 但 现在 ,无 论 要 求 多 么 苛刻 ， 厄 巴 纳 算法 都 能 在 几 
分 钟 内 给 出 一 个 最 棒 的 赛程 表 。 








所 以 兰 迪 才能 在 这 样 完美 的 天 气 带 凯 特 去 看 这 样 一 场 关键 的 棒球 赛 。 虽然 这 天 红 
省 队 的 观 赛 费用 比 平 时 高 ， 但 兰 迪 很 乐意 为 此 买单 。 























兰 迪 和 凯特 进入 看 台 的 时 候 没 有 检票 员 和 检票 闸 机 ， 他 们 就 直接 走 进 了 体育 场 ， 
监控 摄像 头 通 过 人 脸 识 别 软件 认 出 了 他 们 ,通过 数据 匹配 证 实 他 们 已 经 买 过 票 了 。 如 
果 有 人 企图 不 买 票 就 进 场 ,保安 肯定 会 找 出 他 ， 人 们 很 早 就 知道 了 这 一 事实 ,不 敢 冒 
险 去 挑战 识别 软件 的 威力 了 。 
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兰 迪 和 女儿 就 座 后 ， 兰 迪 四 处 打量 ， 发 现价 大 的 球场 空空 荡 荡 ， 看 不 到 几 年 前 巨 
大 的 电视 摄像 机 和 操作 员 了 。 取代 这 些 的 是 围绕 在 球场 周围 的 20 台 小 得 儿 乎 看 不 见 的 
摄影 机 。20 台 摄像 机 的 画面 输入 计算 机 后 ， 软 件 利 用 厄 巴 纳 算法 构建 出 比赛 的 实时 三 
维 演 染 数据 。 从 这 些 演 染 数据 中 ,计算 机 可 以 合成 从 任意 角度 拍摄 球场 任意 地 点 的 视 
频 短 片 。 观众 能 从 捕手 的 视角 观看 比赛 , 也 能 从 跑 垒 员 的 视角 观看 他 滑 向 三 垒 的 英姿 。 
虽然 这 些 画面 其 实 是 计算 机 合成 的 , 但 看 起 来 非常 逼真 。 在 一 次 有 名 的 实验 中 , 请 100 
个 观众 观看 并 排放 在 一 起 的 两 个 短片 ， 其 中 一 个 短片 是 实际 拍摄 的 ， 男 一 个 是 计算 机 
合成 的 。 结 果 89 人 都 误 以 为 计算 机 合成 的 短片 是 实际 拍摄 的 。 










































































新 型 电视 允许 人 们 直接 下 载 三 维 演 染 数据 , 然后 控制 虚拟 的 摄像 机 飞 到 赛场 上 的 
任意 位 置 ， 随 心 所 欲 地 享受 比赛 过 程 。 








计算 机 在 球 棒 击 球 的 那 一 瞬间 ， 准 确 预 测 出 球 的 飞行 轨迹 ， 然 后 立即 选 一 个 最 佳 
的 观看 角度 ， 把 比赛 实时 呈现 出 来 。 运 营 电视 网 络 转播 的 只 有 四 个 人 : 两 个 评论 员 ， 
一 个 制 片 人 ， 还 有 一 个 技术 员 〈 处 理 偶 发 的 故障 )。 评 论 员 说 的 是 英语 ， 而 由 于 圣 路 
易 斯 和 密尔沃基 两 队 分 别 有 一 个 知名 的 日 本 球员 ,这 场 比赛 在 东京 也 很 受 关注 , 那里 
的 观众 听 到 的 将 是 日 语 的 评论 。 实 际 上 日 本 观众 听 到 的 是 美国 的 评论 员 在 说 话 ,但 是 
计算 机 立即 用 语音 识别 、 翻 译 和 语音 合成 工具 模拟 出 地 道 的 日 语 。 这 些 工 具 自 然 也 使 
用 了 厄 巴 纳 算法 。 这 场 比 赛 在 全 世界 用 876 种 语言 和 方言 播 出 。 










































































转播 一 场 比赛 用 四 个 人 似乎 已 经 很 少 了 , 但 在 电视 网 络 的 副 总 裁 看 来 ， 最 好 一 个 
人 都 不 用 。 几 年 以 来 ， 大 学 校园 都 通过 布置 在 球场 周围 的 摄像 机 记录 练习 赛 ， 供 教练 
们 进行 战术 分 析 。 最 近 , 一 个 具有 创业 精神 的 学 生成 功 地 将 厄 巴 纳 算法 应 用 到 这 些 录 
像 数据 上 ， 制 作出 全 套 的 转播 视频 ， 其 中 评论 、 特 写 视角 、 数 据 统计 样 样 俱全 ,一切 
完全 由 计算 机 自动 生成 。 很 快 所 有 大 学 ( 以 及 许多 高 中 比赛 和 小 型 联赛 ) 的 每 种 运动 
赛事 都 可 以 在 互联 网 上 实时 观看 ,还 拥有 各 种 语言 的 版 本 。 这 些 转播 的 质量 也 许 比 不 
上 真人 做 评论 的 那些 节目 ， 但 也 差 不 到 哪里 去 。 
























































幻想 比赛 达到 了 前 所 未 有 的 高 度 。 计 算 机 可 以 生成 体育 迷 们 梦想 中 看 到 的 比赛 ， 
不 仅 可 以 让 不 在 一 支 球 队 的 球星 们 并 肩 作战 ， 甚 至 还 可 以 关公 战 秦琼 ,让 活跃 在 不 同 
时 代 的 球星 同 场 竞技 : 让 全 盛 时 期 的 传奇 投手 赛 ' 杨 对 战 如 日 中 天 的 乔 ' 狄 马 乔 ,或 
是 1927 年 的 洋基 队 对 战 1998 年 的 洋基 队 。 幻 想 与 现实 变 得 难以 区 分 。 某 个 恩人 市， 
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ESPN 电 视 台 的 一 个 计算 机 程序 员 改 写 了 部 分 代码 ， 让 电视 机 前 的 观众 看 到 他 所 喜爱 
的 波士顿 凯 尔 特 人 队 打 败 了 纽约 尼克 斯 队 ， 而 现实 比赛 中 ， 尼 克 斯 才 是 真正 的 胜 者 。 
这 次 转播 事故 让 许多 人 丢 了 饭碗 。 











计算 机 充当 裁判 也 表现 完美 , 它 总 能 精准 无 误 地 判别 坏 球 、 好 球 、 出 局 和 全 从 打 。 
为 了 削减 成 本 ， 小 型 联赛 和 大 学 里 的 所 有 比赛 都 用 计算 机 来 做 裁判 。 而 大 型 联赛 坚持 
使 用 真人 裁判 ， 每 当 错 误 的 判决 改变 比赛 的 局 势 都 会 遭 到 一 片 质疑 之 声 。 




















由 于 担心 计算 机 做 管理 工作 也 比 人 类 经 理 更 为 出 色 ( 这 种 担心 是 正确 的 )， 棒 球 
大 联盟 在 经 历 过 2022 年 世界 巡回 赛 的 失败 之 后 ,宣布 禁止 球 队 使 用 计算 机 设备 。 负 责 
人 称 :“ 这 是 为 了 棒球 运动 好 。 



































兰 迪 一 边 喝 着 啤酒 着 汉堡 ( 饮料 和 食物 变 得 更 好 上 吃 了 ， 因 为 厄 巴 纳 算法 改 

进 了 配方 )， DRE A: 比赛 进行 的 方式 和 他 小 的 时 候 相 比 没有 什么 变化 。 

他 其 实 完全 可 以 省 下 大 笔 钱 ， 在 家 里 欣赏 从 完美 视角 呈现 的 比赛 三 维 实况 转播 。 尽 管 

科技 让 在 家 看 球 的 体验 远 比 在 体育 场 看 球 还 要 好 ， 兰 迪 还 是 愿意 享受 一 种 参与 感 , JE. 
巴 纳 算法 再 厉害 也 无 法 再 现 这 种 感情 上 的 依恋 。 























计算 机 可 以 自动 生成 计 分 表 , 但 兰 迪 还 是 教 女 儿 凯 特 怎样 在 纸 上 计 分 ， 就 像 他 父 
亲 教 他 的 那样 。 纵 使 以 厄 巴 纳 算 法 为 代表 的 科技 改变 了 几乎 所 有 的 事物 ， 但 比赛 还 是 
那个 比赛 。 三 振 出 局 的 老 规矩 ， 永 远 都 不 会 改变 。 
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为 何 形式 简单 的 计算 机 代码 ， 只 要 强大 到 厄 巴 纳 算 法 那 种 级 别 ， 就 能 带 给 我 们 一 
个 理想 的 世界 ， 让 人 们 可 以 治愈 疾病 、 预 测 天 气 ， 以 及 创造 几乎 能 够 以 假 乱 真 的 虚拟 
环境 ?” 为 了 回答 这 个 问题 ， 我 们 需要 回 到 14 世 纪 的 早期 。 








奥 卡 姆 的 威廉 还 是 一 名 青年 时 就 加 入 了 英国 的 方 济 各 会 。 和 许多 14 世 纪 的 宗教 团 
体 一 样 ， 方 济 各 会 的 总 部 设 在 牛津 ， 它 为 牛津 大 学 的 在 校生 提供 了 住所 。 威 廉 是 一 名 
主 修神 学 的 牛津 学 生 ， 尽 管 没有 毕业 ， 他 后 来 还 是 成 了 中 世纪 最 主要 的 思想 家 之 一 ， 
对 物理 学 、 神 学 、 逮 辑 学 和 哲学 都 作出 了 巨大 贡献 。 他 最 著名 的 思想 是 奥 卡 姆 剃刀 法 










































































18 ， 可 能 与 不 可 能 的 边界 ，P/NP 问 题 趣 史 








则 ， 即 主张 最 简单 的 解释 通常 是 最 好 的 解释 。“ 剃 刀 ” 一 词 比 喻 我 们 可 以 把 一 个 理论 
中 纠缠 复杂 的 部 分 像 明 子 一 样 “ 剃 除 "， 只 留 下 最 简单 的 解释 。 这 一 思想 贯穿 文艺 复 
兴 时 代 一 直 延 续 到 今天 ， 引 领 着 一 代 又 一 代 人 的 科学 和 哲学 思潮 。 






























































17 世 纪 法 国 哲 学 家 勒 内 : 笛 卡 儿 通 晓 奥 卡 姆 闲 刀 法 则 。 他 怀疑 一 切 ， 甚 至 对 周围 
世界 的 存在 性 提出 质疑 。 笛 卡 儿 最 为 著名 的 哲学 命题 是 Cogito ergo sum, B RE 
我 在 ”。 在 他 的 著作 《方法 论 》 中 ， 笛 卡 儿 据 弃 了 一 切 前 提 假 设 ， 仪 从 他 能 通过 思考 
意识 到 自己 这 一 点 ， 得 出 了 “ 笛 卡 儿 是 存在 的 ”这 一 结论 。 那 么 笛 卡 儿 如 何 解 释 他 感 
受到 的 复杂 世界 呢 ? 万 物 是 否 有 可 能 只 存在 于 笛 卡 儿 的 意识 中 ? 笛 卡 儿 不 赞同 这 种 
想法 ， 因 为 有 另 一 种 更 简单 和 更 合理 的 解释 ， 那 就 是 其 他 人 和 他 一 样 ， 大 家 共同 生活 
在 一 个 可 以 认 知 和 理解 的 物质 世界 之 中 。 







































































我 被 “我 思 故 我 在 ”这 几 个 字 迷 住 了 ,我 确信 它 是 真理 , 证 据 只 有 一 条 ， 
那 就 是 我 清楚 地 看 到 ， 存 在 是 一 个 事物 能 够 思辨 的 必要 前 提 。 我 甚至 可 以 论 
断 ， 一 般 地 讲 ， 一 切 我 们 能 清晰 明确 地 在 脑 中 显现 的 事物 都 是 真实 的 。 然 而 
值得 注意 的 问题 是 ， 很 难 恰当 地 分 辨 哪些 物体 是 我 们 能 够 明确 地 想象 的 。 


EPL, (FE), PRA 











和 第 卡 儿 同时 代 的 约翰 内 斯 * 开 普 勒 通过 观测 行星 运动 ， 归 纳 出 了 一 系列 描述 它 
们 运动 路 线 和 速度 的 定律 。 至 于 为 什么 行星 运动 符合 这 些 定律 ， 开 普 勒 无 法 给 出 一 个 
简单 的 解释 。 








艾 萨 克 牛顿 将 奥 卡 姆 剃刀 法 则 运用 到 物理 世界 。 他 著名 的 运动 定律 以 非常 简单 
的 方式 ， 表 述 了 物体 如 何 相互 作 用 : 


1. 如 果 不 给 物体 施加 任何 力 , 静止 的 物体 会 保持 静止 , 运动 的 物体 速度 保持 不 变 ; 

2. 施加 于 物体 上 的 力 将 产生 一 个 与 其 大 小 成 正比 的 国定 加 速度 ; 

3. 一 个 物体 给 另 一 个 物体 施加 力 ， 则 施 力 物 体 也 会 受到 来 自 受 力 物体 的 大 小 相等 、 
方向 相反 的 力 。 





























通过 把 运动 定律 和 他 对 引力 的 简单 描述 相 结合 , 牛顿 展示 了 如 何 从 天 体 的 运动 推 
导出 开 普 蔓 定 律 。 简 单 的 表述 可 以 具有 强大 的 解释 能 








几 个 世纪 后 ， 阿 尔 伯 特 ' 爱 因 斯 坦 和 其 他 科学 家 从 理论 上 提出 : 对 于 运动 速度 接 
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近 光 速 的 物体 ， 牛 顿 的 简单 运动 定律 是 不 成 立 的 。 后 来 的 一 些 实验 基本 证 明 爱 因 斯 坦 
是 对 的 。 他 的 名 言 是 :“ 把 所 有 事 都 变 得 尽 可 能 简单 ， 而 不 可 过 于 简单 。” 这 并 不 意味 
着 牛顿 错 了 , 恰恰 相反 ,他 的 模型 是 对 我 们 所 认 知 的 世界 的 一 个 很 好 的 近似 。 甚 至 在 
今天 ， 对 于 包括 驾驶 汽车 ， 以 及 高 中 大 部 分 科学 实验 在 内 的 一 些 简单 场合 ， 牛 顿 定律 
仍然 非常 适用 。 












































对 于 非常 小 的 粒子 ,甚至 爱 因 斯 坦 的 理论 也 不 再 成 立 , 它们 所 服从 的 法 则 被 称 为 
量子 力学 。 当 代 物 理学 家 试图 找到 一 种 能 融合 爱 因 斯 坦 的 广义 相对 论 和 量子 力学 的 理 
论 ， 即 所 谓 的 “大 统一 理论 ”。 























简单 的 模型 永远 无 法 反映 世界 全 部 的 复杂 性 ， 但 它们 通常 可 以 很 接近 这 个 目标 。 
为 某 些 情形 找到 一 种 简单 的 解释 ， 就 能 对 未 来 发 生 的 类 似 情形 做 出 很 好 的 预测 。 近 年 
来 我 们 看 到 这 个 原理 在 计算 机 科学 世界 得 到 了 充分 的 体现 。 


























今天 我 可 以 手写 一 张 支票 ， 用 手机 拍 张 支票 的 照片 ， 然 后 通过 互联 网 存 人 支票 。 
银行 的 软件 通过 照片 就 能 识别 交易 金额 和 账号 ， 即 使 支票 是 手写 的 也 没关系 。 如 果 没 
有 疑 议 ,银行 职员 甚至 都 不 用 亲自 去 看 这 张 支 票 。 












































B 


识别 位 于 支票 底部 的 账号 比较 容易 ， 组 成 账号 的 数字 符合 固定 的 格式 ,这 是 特 
为 方便 计算 机 识别 而 设计 的 。 





但 是 支票 上 的 金额 是 手写 的 “30 美 元 "。 每 个 人 写字 的 方式 都 不 一 样 ， 计 算 机 如 
何 能 判别 这 张 支票 的 金额 呢 ? 
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图 2-1 支票 
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这 个 问题 不 简单 。 不 信 你 看 数字 2 有 多 少 种 写法 。 


23227727272 
22229)2z2i1zz2 


AZALI LARA 
AZ42a2l1a2aa2aAz 
24812212222 
2B222227-.2272 
2-»37:722222722 
AL4T42414d2 
DdéLA2723272 
2o0pogz2242 


图 2-2 各 种 手写 的 数字 2 





计算 机 科学 的 一 个 分 支 一 一 机 带 学 习 就 是 处 理 这 类 问题 的 。 首 先 用 大 量 的 数据 训 
练 一 个 算法 ， 在 这 个 例子 里 ， 数 据 就 是 人 们 写 数字 2 和 其 他 数字 的 样 例 。 算 法 会 建立 
一 个 相对 简单 的 模型 ,然后 尝试 用 这 个 模型 正确 区 分 各 种 手写 的 数字 。 训 练 得 好 的 算 
法 能 对 新 的 数字 进行 正确 的 分 类 ， 即 使 是 对 训练 期 之 后 写 出 的 数字 也 不 例外 。 


过 去 20 年 ， 计 算 机 科学 家 在 机 器 学 习 领 域 取 得 了 长 足 的 进步 ， 研 究 出 了 通过 检查 
几 千 到 几 百 万 样 例 ， 计 算出 将 数据 分 类 的 正确 方式 。 除 了 识别 支票 之 外 ,许多 照片 处 
理 程序 还 可 以 根据 人 脸 来 对 照片 排序 ， 效 果 还 过 得 去 。Amazon 、Netflix 和 了 Pandora 等 
公司 能 为 顾客 推荐 图 书 、 电 影 和 音乐 ， 根 据 的 是 顾客 之 前 购买 过 的 商品 ， 以 及 观 影 和 
听 歌 的 模式 。 语 音 识别 和 语言 翻译 虽然 不 能 做 到 和 真人 一 样 ， 但 会 让 你 大 致 了 解 写 的 
或 说 的 是 什么 。 垃 圾 邮件 识别 工具 屏蔽 了 人 们 不 想 要 的 几乎 所 有 信息 。 到 2020 年 ， 所 
有 的 汽车 有 望 能 够 自动 驾驶 。 





















































这 类 技术 所 能 做 到 的 差不多 就 是 这 些 了 , 未 来 取得 的 进步 最 终 将 越 变 越 小 。 这 是 
和 否 意味 着 奥 卡 姆 剃刀 不 再 锋利 ， 宝 刀 已 老 ? 




















倒 也 未 必 。 奥 卡 姆 剃刀 法 则 说 的 是 最 简单 的 解释 问题 的 方法 就 是 最 好 的 方法 , 但 它 
并 没有 告诉 你 如 何 找到 那个 最 简 表 述 。 如 今 的 机 顺 学 习 技 术 只 能 使 用 简单 的 数据 表述 方 
X, 通常 会 把 数据 的 多 种 特征 用 相对 直接 的 方式 加 以 合并 。 如 何 找到 最 简 表 述 ， 即 找到 
任意 形式 的 程序 中 最 短小 而 有 效 的 数据 分 类 程序 ， 是 一 个 困难 的 问题 ， 一 个 NP 问题 。 
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果 能 使 用 快速 解决 所 有 NP 问题 的 厄 巴 纳 算法 ,找到 最 简单 的 数据 分 类 程序 就 变 
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成 了 一 道 简单 的 编程 练习 。 我 们 需要 做 的 只 是 把 海量 数据 交 给 算法 ,然后 看 着 它 完 
剩 下 的 工作 。 这 样 一 来 ,我们 几乎 能 了 解 所 有 的 事物 。 











我 们 已 经 看 到 了 厄 巴 纳 算法 帮助 人 类 治愈 了 很 多 疾病 , 并 且 改变 了 美国 的 棒球 运 
动 。 接 下 来 让 我 们 回 到 未 来 ， 看 看 它 是 如 何 改 变 艺 术 的 。 











2.5 ”创造 力 的 自动 化 





借助 奥 卡 姆 剃刀 , 厄 巴 纳 算法 几乎 能 让 我 们 了 解 一 切 , 包括 艺术 作品 为 何 优秀 , 音 
乐 为 何 流行 ， 言 语 为 何 动 人 心 饮 。 要 知道 P= NP 意味 着 只 要 能 评测 一 个 事物 ， 我 们 就 
能 找到 它 。 所 以 只 要 有 一 个 慧眼 识 珠 的 算法 ,再 用 厄 巴 纳 算法 就 能 很 快 找到 这 颗 “ 明 珠 ”。 








2022 年 ， 美 国民 主 党 总 统 候选 人 初 选 即 将 在 科罗拉多 州 开始 。 之 前 的 两 周 ， 皮 
地， 约翰逊 得 票 第 三 ， 远 远 落 后 于 前 两 名 。 情 况 在 “ 那 次 演讲 ”后 改变 了 。 在 韦 尔 市 
的 一 个 小 剧场 里 ， 约 翰 逊 进行 了 一 次 短 短 10 分 钟 的 演讲 ， 甚 至 没有 媒体 列席 。 然 而 这 
次 有 关 科 罗拉 多 和 美国 的 演讲 格外 动人 心 饱 ， 在 场 的 32 个 人 起 立 报 以 热烈 的 掌声 。 















































一 个 与 会 者 用 手机 录 下 了 演讲 ， 发 到 了 网 上 。 几 百 万 人 在 线 观 看 了 演讲 ， 后 来 甚 
至 有 几 千 人 言 之 凿 谐 ， 说 自己 亲临 了 那 次 演讲 。 约 翰 逊 赢得 了 初 选 ， 成 为 2024 年 总 统 
竞选 的 热门 候选 人 。 为 进一步 提高 自己 的 曝光 率 , 皮特 ' 约 翰 逊 炒 了 自己 的 竞选 经 理 ， 
然后 换 了 一 个 享誉 全 国 的 专家 。 








被 炒 的 前 竞选 经 理念 分 不 平 ， 召 开 记 者 会 爆料 了 那 次 演讲 背后 的 真相 。 当 时 情况 
不 妙 ， 如 果 不 马 上 使 出 一 些 厉 害 手段 ， 皮 特约 验 逊 的 竞选 之 旅 眼看 就 要 到 头 了 。 于 
是 ,竞选 经 理 雇 了 一 个 计算 机 程序 员 ， 程 序 员 先 下 载 了 数 以 万 计 的 近 几 十 年 来 广 受 欢 
迎 的 演讲 ， 然 后 用 厄 巴 纳 算法 生成 了 一 个 关于 科罗拉多 及 国内 外 局 势 的 优秀 演讲 稿 。 
皮特 约翰逊 经 过 多 次 排练 ， 把 计算 机 生成 的 稿子 背 得 滚 瓜 烂熟 ， 然 后 才 有 了 韦 尔 市 
的 演讲 。 竞 选 经 理 请 观众 把 此 次 记者 会 的 录像 也 传 到 网 上 。 















































从 一 片 哗然 。 有 些 人 表示 愤慨 ， 另 一 些 则 认为 政客 们 的 演讲 稿 是 由 职业 撰 稿 人 
提 刀 还 是 由 计算 机 生成 没 多 大 差别 。 皮 特 ， 约翰 逊 失 掉 了 民心 ， 也 失掉 了 大 选 。 到 
2026 年 的 时 候 ， 几 乎 所 有 候选 人 撰写 演讲 稿 时 都 会 让 计算 机 帮忙 甚至 代劳 ， 大 家 习 以 
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为 常 ， 见 怪 不 怪 。 当 然 ， 人 人 演讲 出 色 ， 等 于 没 人 演讲 出 色 。 








古典 音乐 家 用 厄 巴 纳 算法 完成 大 师 们 未 完成 的 名 作 ， 如 普 契 尼 的 歌剧 《图 兰 人 条》、 
马 勒 的 《第 十 交响 曲 》 舒 伯 特 的 《第 八 交响 曲 》( 又 名 《未 完成 交响 曲 》); 而 且 还 能 
再 续 经 典 ， 如 创作 出 贝多 芬 的 第 十 部 交响 曲 。 由 算法 生成 的 最 著名 的 交响 曲 叫做 《 厄 
巴 纳 第 一 交响 曲 》 古典 乐 迷 非 常 喜 爱 它 。 有 人 甚至 用 厄 巴 纳 算 法 制作 出 甲壳 虫 和 猜 
王 的 新 专辑 , 将 已 故 歌星 们 的 嗓音 模仿 得 惟妙惟肖 。 音乐 评论 界 的 专家 对 这 些 “ 作 品 ” 
喷 之 以 稀 ， 认 为 它们 只 是 照 猫 画 虎 ， 缺 乏 真 正 的 创意 ， 但 还 是 有 很 多 人 下 载 。 





















































还 有 人 用 计算 机 生成 新 的 画作 、 小 说 、 戏 剧 和 诗歌 。 一 个 电影 爱好 者 最 近 制 作 
了 一 部 由 盛 年 的 享 弗 莱 : 鲍 嘉 和 茶 莉 娅 ， 罗 伯 菊 主演 的 爱情 喜剧 片 ， 看 起 来 就 好 像 
两 人 真 的 穿越 了 时 光 ， 在 片场 大 闫 感情 戏 一 样 。 想 看 由 导演 带 姆 : 伯 顿 执 镜 的 《 绿 
野 仙 踪 》? 没 问题 ! 

















Amazon 能 做 的 超越 了 原来 的 图 书 推荐 。 你 只 要 花 一 张 电影 票 的 钱 ， 就 可 以 让 
Amazon 写 一 部 完全 符合 你 口味 的 小 说 。NBC 电 视 台 目前 推出 了 一 档 “ 现 场 直 播 ”的 
动作 冒险 剧 集 , 完全 由 计算 机 创作 , 不 需要 任何 编剧 和 演员 。 最 新 的 Xbox 上 的 电子 游 
戏 带 给 你 沉浸 式 的 叙事 和 世界 体验 。 故 事 的 发 展 不 再 是 线性 的 ， 而 是 有 着 无 限 的 可 能 
性 ， 玩 家 完全 按 自 由 意志 行动 ， 并 为 自己 的 行为 承担 相应 的 后 果 。 不 少 人 觉得 难以 区 
分 游戏 和 现实 生活 ， 比 较 明显 的 区 别 是 现实 生活 可 能 没有 游戏 那么 刺激 。 







































































这 些 新 的 娱乐 选择 让 世人 目 胶 神 迷 ,为 之 痴狂 。 许 多 文章 都 在 批判 真实 表达 的 缺 
失 。 究 竟 厄 巴 纳 算法 标志 着 一 个 艺术 新 纪元 的 诞生 ， 还 是 人 类 创造 力 的 死亡 ， 这 在 未 
来 的 几 个 世纪 仍 是 一 个 争议 不 断 的 话题 。 














2.6 ”终极 侦探 





司法 机 关 觉得 厄 巴 纳 算 法 在 侦破 犯罪 案件 方面 堪 称 鬼才 , 它 在 追捕 嫌犯 时 总 是 能 
完成 不 可 能 完成 的 任务 。 然 而 也 有 一 些 争 议 。 


后 厄 巴 纳 算法 时 代 的 亚特兰大 出 现 了 一 起 多 人 死亡 的 凶杀 案 , 警方 从 犯罪 现场 的 
央 餐 包装 纸 上 收 集 到 了 一 份 DNA, 但 在 美国 DNA 联 合 索引 系统 (CODIS ) 中 找 不 到 与 
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之 匹配 的 数据 。 佐治 亚 理 工学 院 的 一 个 计算 机 科学 家 用 厄 巴 纳 算法 和 CODIS 创 建 了 一 
个 新 的 程序 , 该 程序 不 仅 可 以 利用 这 些 DNA 数 据 预测 嫌犯 的 身高 、 眼 睛 和 皮肤 颜色 等 
外 貌 特征 ,还 能 预测 嫌犯 的 个 性 特点 以 及 可 能 从 事 的 行业 。 然 后 这 个 计算 机 科学 家 带 
领 学 生 , 把 CODIS 中 的 DNA 数 据 和 这 些 人 的 面部 照片 匹配 ， 从 而 研发 出 一 种 技术 , TR 
据 某 人 的 DNA 生 成 相貌 的 大 臻 素描， 前 提 是 知道 目标 的 年 龄 和 面部 毛发 类 型 。 



























































于 是 警方 想 用 这 个 算法 找到 和 犯罪 现场 DNA 匹 配 的 罪犯 头像 照片 ， 但 没有 成 功 。 
他 们 又 把 算法 运行 在 驾驶 执照 的 头像 数据 库 里 ， 这 回 找到 了 一 个 嫌疑 人 一 一 乔治 布 
朗 ， 几 小 时 后 把 他 抓 了 进来 。 乔 治 ' 布朗 没有 不 在 场 的 证 明 ， 而 且 是 唯一 符合 由 DNA 
生成 的 相貌 素描 的 人 , 但 除 此 之 外 ,没有 发 现 他 与 此 次 犯罪 有 明显 关联 。 他 拒绝 提供 
DNA 样 本 , 警方 得 到 了 法 院 的 搜查 令 , 然后 比 对 了 他 和 犯罪 现场 留 下 的 DNA, 果然 相 
符 。 乔 治 * 布 明 被 认定 有 罪 ， 判 处 死刑 。 












































布朗 提出 上 诉 ， 他 的 律师 说 根据 犯罪 现场 留 下 的 DNA 画 出 素描 的 行为 侵犯 了 乔 
治 ' 布朗 的 隐私 权 。 美 国 最 高 法 院 裁定 ,使 用 DNA 判 定 一 个 人 的 身份 是 合法 的 。 和 警方 
只 是 将 算法 运行 在 合法 取得 的 证 据 上 。 
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然而 , 此 案 引 发 了 公众 对 丧失 隐私 权 的 大 规模 抗议 。38 个 州 决定 DNA 只 能 用 来 匹 
配合 法 收录 到 CODIS 中 的 嫌犯 ， 除 此 之 外 不 能 使 用 。 最 后 ， 佐 治 亚 州 州长 将 乔治 ' 布 
关 的 死刑 改判 为 终身 监禁 。 


2.7 ”美妙 世界 的 阴暗 面 





以 前 人 们 依靠 公 钥 加 密 技 术 , 可 以 不 经 过 初始 化 设置 就 安全 地 通过 网 络 将 信用 卡 
号 传 给 交易 公司 。 而 厄 巴 纳 算法 能 在 瞬间 破解 公 钥 加 密 。 起 初 ， 电 子 商 务 的 发 展 经 历 
了 一 些 挫折 , 但 互联 网 巨头 们 很 快 就 联合 起 来 ， 将 业务 迁移 到 使 用 私 钥 加 密 的 系统 。 
很 快 一 个 私 钥 注 册 处 被 建立 起 来 ， 人 们 从 街 边 的 药店 就 能 买 到 一 个 密 钥 U 盘 ， 里 面 装 
着 儿 十 亿 个 一 次 性 的 私 钥 。 虽 然 比 原来 稍 显 不 便 , 但 是 电子 商务 活动 又 兴旺 起 来 。 
































更 多 人 感到 个 人 隐私 被 剥夺 ， 并 对 此 感到 怒 懂 。 原 来 看 起 来 人 畜 无 害 的 视频 摄像 
头 突然 能 识别 和 追踪 每 个 人 了 。 更 丸 怖 的 是 ， 计 算 机 算法 能 准确 预测 你 走 哪 条 路 ， 听 
什么 歌 , 看 什么 电影 ， 买 什么 产品 ,简直 比 你 自己 还 了 解 你 。 定 向 投放 的 广告 很 容易 
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就 能 诱导 你 改变 消费 习惯 。 被 认为 可 能 是 雳 贼 或 恐怖 分 子 的 人 会 立刻 被 系统 认 出 来 ， 
受到 严密 的 监视 。 


对 厄 巴 纳 算法 最 大 的 顾虑 是 就 业 问题 。 从 秘书 到 中 层 管 理 人 员 ， 几乎 所 有 的 日 领 
职位 都 受到 算法 的 威胁 ， 它 可 以 理解 各 种 信息 ( 甚至 包括 不 太 正 式 的 电子 邮件 、 音 频 
和 视频 )， 生 成 信件 和 报表 ， 还 能 根据 分 析 得 出 结论 和 制定 决策 。 那 些 原来 需要 外 包 
的 工作 都 交 给 计算 机 算法 做 就 行 了 ， 这 被 称 为 “ 厄 巴 纳 包 ”。 工 作 人 员 如 果 不 能 让 雇 
主 相信 自己 提供 的 附加 价值 ， 就 会 失业 。 大 公司 继续 理直气壮 地 削减 薪资 。 不 少 公 司 
撤销 了 设 在 海外 的 人 工 咨询 台 服 务 , 代 之 以 计算 机 化 的 支持 多 种 语言 和 方言 的 应 答 系 
统 。 许 多 消费 者 在 民意 测验 中 表示 计算 机 提供 的 服务 比 被 取代 的 人 工 服 务 更 加 有 用 。 





























有 些 国 家 开始 立法 限制 厄 巴 纳 算法 的 应 用 以 保护 就 业 岗 位 , 但 在 来 自 其 他 国家 的 
商业 竞争 压力 面前 ， 这 些 法 律 很 快 就 被 废止 了 。 人 情况 逐渐 有 了 一 些 转 好 的 迹象 。 厄 巴 
纳 算法 刺激 了 疲软 的 经 济 ， 催 生 了 新 兴 产 业 的 锥 形 。 大 学 里 开设 了 新 的 课程 ， 如“ 厄 
巴 纳 优化 ”， 讲 授 拿 到 一 个 问题 后 如 何以 最 快捷 简便 的 方式 运用 厄 巴 纳 算法 解决 它 。 
虽然 长 远 来 看 , 算法 创造 的 就 业 机 将 会 远 远 多 于 失去 的 就 业 机 会 , 但 还 是 有 许多 人 对 
算法 耿耿 于 怀 ， 蔡 那些 无 法 适应 新 经 济 体制 的 失业 者 鸣 不 平 。 















































政府 继续 推行 法 令 ， 保护 民 众 不 受 厄 巴 纳 算法 的 冲击 ， 但 科技 的 影响 覆 水 难 收 。 
人 类 总 是 能 很 快 适 应 新 形势 ,渐渐 很 少 有 人 会 在 民意 测验 中 表示 愿意 时 光 倒 流 ， 回 到 
古老 的 2012 年 ， 逃 离 这 个 算法 带 来 的 美妙 世界 。 











2.8 回 到 现实 


觉得 一 个 算法 能 改变 一 切实 在 令 人 难以 置信 ? 只 要 能 辨识 , 就 能 找到 ?我 们 能 轻 
松 了 解 所 有 事物 ?确实 不 太 可 能 , 因而 大 部 分 计算 机 科学 家 都 认为 P# NP , 即 永远 不 
会 发 现 厄 巴 纳 算法 或 是 类 似 的 算法 。 


























无 论 P/NP 问 题 的 命运 如 何 ， 本 章 出 现 的 故事 中 有 一 部 分 还 是 可 能 会 变 成 现实 的 。 
但 那 将 是 一 场 持久 战 ， 我 们 必须 脚踏实地 ， 逐 个 攻破 技术 难关 ， 而 不 是 只 靠 神 奇 的 计 
算 机 代码 去 解决 所 有 的 问题 。 人 类 的 创造 力 是 很 强大 的 ， 只 要 有 梦想 在 前 方 召唤 ,我 
们 最 终 一 定 能 设法 到 达 。 








31 敌 友 国 


为 了 更 好 地 了 解 P 和 NP， 让 我 们 访问 一 个 假想 中 的 国度 一 一 敌 友 国 。 在 那里 , 任 
意 两 个 人 之 间 的 关系 不 是 朋友 ， 便 是 敌人 。 























敌 友 国 住 着 2 万 居民 。 单 看 每 个 人 都 很 正常 ， 但 是 把 两 个 人 放 在 一 起 就 会 发 生 奇 
怪 的 事情 。 他 们 见 到 对 方 的 第 一 上 腿 ， 要 么 立刻 变 成 最 好 的 朋友 ， 要 么 马上 变 成 最 坏 的 
敌人 。 虽 然 叫 敌 友 国 ， 但 从 没 看 到 过 两 个 人 的 关系 会 有 中 间 立 场 ， 而 是 非 敌 即 友 。 






































看 上 去 敌 友 关系 几乎 是 随机 建立 的 。 朋 友 的 朋友 不 一 定 是 朋友 ， 也 可 能 是 敌人 ， 
敌人 的 敌人 亦 然 。 它 和 性 别 、 种 族 、 信 仰 和 社会 地 位 都 没什么 关系 ， 不 过 人 们 更 倾向 
于 树 敌 而 不 是 交友 ， 大 部 分 人 的 朋友 数量 都 要 比 敌人 少 很 多 。 


























互联 网 提供 了 大 量 敌 友 国 中 朋友 关系 的 数据 。 通 过 检查 Facebook 和 Twitter， 敌 友 
国 理工 学 院 的 计算 机 科学 家 们 获得 了 几乎 完整 的 数据 库 ， 里面 记录 了 哪 两 个 人 是 朋 
A, 哪 两 个 是 敌人 。 在 本 章 , 我 们 将 看 到 研究 者 能 利用 这 些 数据 做 什么 , 不 能 做 什么 。 























3.2 ”六 度 理 论 


随便 从 政 友 国 挑 两 个 人 出 来 ,不 妨 叫 他 俩 Alice 和 George， 两 个 人 互 为 朋友 的 可 能 
性 很 低 。 但 他 们 可 能 有 一 个 共同 的 朋友 Bob ， 也 可 能 没有 这 么 一 个 人 。 至 友 国 理工 学 
院 的 计算 机 科学 家 把 全 国 的 人 标记 在 一 张 散 点 图 上 ( 每 个 点 代表 一 个 人 )， 并 在 代表 
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朋友 关系 的 两 点 之 间 连 一 条 线 。 这 张 图 的 一 部 分 像 下 面 这 样 。 
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图 3-1 WA ESL COR ERST 
































研究 者 发 现 要 连接 Alice 和 George， 中 间 要 经 过 6 个 人 : Alice 和 了 Bob 是 朋友 ，Bob 和 
Cathy 是 朋友 ，Cathy 和 David 是 朋友 ，David 和 Eve 是 朋友 ，Eve 和 Fred 是 朋友 ，Fred 和 
George 是 朋友 。 政 友 国 的 科学 家 想 ， 是 不 是 任意 两 个 人 都 能 通过 一 条 足够 短 的 好 友 链 
联系 起 来 。 这 个 现象 称 为 “小 世界 ”， 不 是 得 名 于 迪士尼 乐园 里 那个 游乐 项 目 ， 而 是 
因为 两 个 卫生 人 见面 ， 通 过 攀谈 发 现 彼此 竞 然 七 抛 八 弯 地 有 关联 时 ， 通 常会 说 :“ 世 
AE ERUNT 





































































































1967 年 心理 学 家 斯 坦 利 - 米尔 格拉 姆 做 了 一 个 著名 的 实验 来 检验 小 世界 理论 。 他 
首先 挑选 了 一 个 波士顿 地 区 的 股票 经 纪 人 ， 真 名 不 便 透 露 ， 我 们 不 妨 叫 他 汤姆 琼斯 。 
米尔 格拉 姆 随机 选择 了 100 个 来 自 内 布 拉 斯 加 州 炒股 的 人 作为 第 一 组 ，100 个 不 炒股 的 
人 作为 第 二 组 ， 另 外 还 有 从 波士顿 登 报 招募 的 100 人 作为 第 三 组 。 来 自 内 布 拉 斯 加 州 
的 第 二 组 人 和 波士顿 第 三 组 的 人 跟 投 资 行当 没什么 特殊 的 联系 。 米 尔格 拉 姆 给 每 个 人 

个 装 有 实验 指令 的 档案 夹 、 一 本 花 名 册 ， 以 及 15 张 贴 了 邮票 能 寄 给 哈佛 大 学 米尔 格 
拉 姆 的 明信片 。 实 验 指令 是 这 样 写 的 。 

































































1. 把 你 的 名 字 添 到 人 花 名 册 上 。 
2. 拿 一 张 明 信 片 ， 把 它 塞 到 邮 简 里 寄 出 去 。 
3. 如 果 你 和 波士顿 的 股票 经 纪 人 汤姆 : 琼斯 有 私交 ， 请 把 这 个 档案 夹 寄 给 他 。 
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4. 如 果 你 不 认识 汤姆 忒 斯 ， 把 档案 夹 寄 给 一 个 你 认识 的 人 ， 这 个 人 的 名 字 没 有 
出 现在 花 名 册 上 ， 而 且 你 觉得 他 更 有 可 能 认识 汤姆 : 琼斯。 




















300 个 人 中 总 共有 217 个 把 档案 寄 给 了 自己 的 朋友 , 其 中 有 64 份 档案 最 终 到 了 股票 
经 纪 人 那里 。 好 友 链 的 平均 长 度 是 5.2 个 人 ,从 而 产生 了 所 谓 六 度 分 割 的 概念 ,就 是 说 
任何 人 最 多 经 过 6 个 人 就 能 认识 所 有 人 。 尽 管 许多 人 从 多 方面 指出 了 米尔 格拉 姆 研究 
的 不 足 ， 并 且 他 本 人 从 没有 声称 自己 发 现 了 六 度 空间 法 则 ， 但 是 很 明显 ,我们 所 有 人 
之 间 的 联系 比 预想 中 更 为 紧密 。 





























如 果 要 用 某 种 比 仅仅 听 说 过 某 人 更 为 明确 的 方式 来 定义 两 人 之 间 有 关联 ,可 以 分 
析 一 下 现实 中 的 人 际 网 络 。 这 启发 了 一 些 休闲 时 玩 的 小 游戏 ,基本 玩法 是 看 看 某 人 与 
一 个 特定 的 交际 很 广 的 人 的 距离 有 多 远 。1994 年 ,演员 凯 文 * 贝 肯 在 宣传 他 出 演 的 电 
影 《 狂 野 之 河 》( The River Wild ) 时 开 了 一 个 玩笑 ， 说 他 和 好 莱 坞 的 每 个 人 都 共事 过 ， 
或 者 说 ， 他 和 某 个 跟 每 个 人 都 共事 过 的 人 一 起 共事 过 。 于 是 大 家 开始 玩 “ 凯 文 ， 贝 肯 
的 六 度 空间 ”这 个 小 游戏 , 试 着 找 出 任意 一 个 演员 和 凯 文 * 贝 肯 之 间 联 系 的 途径 ， 而 
对 两 人 之 间 有 关联 的 定义 是 出 演 过 同一 部 片子 。 这 样 一 来 ， 大 部 分 演员 和 凯 文 * 贝 肯 
的 关系 链 都 很 短 ， 所 以 其 实 他 们 彼此 之 间 也 很 近 。 例 如 ， 从 查理 : 卓 别 林 到 凯 文 .由 
肯 的 关系 链 长 度 为 3: 卓 别 林 执 导 了 1967 年 的 电影 《香港 女 伯 栈 》( 4 Countess from 
Hong Kong ) 并 在 其 中 扮演 了 一 个 小 角色 ， 女 伯 天 由 索菲亚 .罗兰 扮演 ; 索菲亚 罗 
兰 主演 了 1979 年 名 不 见 经 传 的 电影 《火力 》( Firepower ); 伊 菜 . 瓦 拉 赫 是 《火力 》 的 
主要 演员 之 一 ， 在 《神秘 河 》( Mystic River) 中 他 扮演 了 一 个 跑龙套 的 小 角色 ， 而 凯 
文 ， 贝 肯 也 参 演 了 该 片 。 



























































数学 家 们 也 有 一 个 类 似 的 游戏 , 通过 “曾经 共同 撰写 一 篇 论文 ”这 种 关系 ， 看 看 
某 个 数学 家 离 发 表 著 作 很 多 的 组 合 数学 家 保罗 ，. 爱 多 士 有 多 远 。” 























敌 友 国 的 研究 者 决定 首先 检验 六 度 空 间 法 则 在 他 们 的 国家 是 否 成 立 。 要 检验 Alice 
和 George 之 间 是 和 否 有 长 度 为 6 的 关系 链 ， 一 个 简单 的 方法 是 检查 所 有 长 度 为 6 的 关系 链 ， 
看 看 其 中 是 否 有 一 条 以 Alice 和 George 为 端点 。 但 是 对 于 敌 友 国 的 2 万 居民 , 所 有 长 度 为 6 
的 关系 链 有 3 198 400 279 980 000 480 000 种 可 能 ， 即 使 计算 机 每 秒 能 检查 1 万 亿 条 关系 





























我 和 三 个 与 保罗 . 爱 多 十 合 著 过 论文 的 人 一 起 写 过 论文 ， 所 以 我 的 “ 爱 多 土 分 数 ” 是 2。 爱 多 土 于 
1996 年 辞世 , 所 以 我 不 太 可 能 刷新 这 个 分 数 了 。 我 没有 演戏 的 经 历 ( 或 天 赋 ), 所 以 没有 “ 贝 肯 分 数 ”。 
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链 , 也 需要 100 多 年 才能 检查 完 。 有 没有 更 好 的 方法 来 检查 Alice 和 George 之 间 的 距离 呢 ? 
有 。 可 以 用 几 个 简单 的 步骤 来 快速 找 出 Alice 和 George 之 间 的 距离 有 多 远 。 


o 把 点 Alice 标 为 0。 

a 把 所 有 Alice 的 朋友 的 点 标 为 1。 

a 遍历 所 有 标记 为 1 的 点 , 把 每 个 点 的 朋友 标 为 2( 除去 那些 已 经 标记 了 点 的 人 )。 
D 遍历 所 有 标记 为 2 的 点 , 把 每 个 点 的 朋友 标 为 3( 除去 那些 已 经 标记 了 点 的 人 s 
口 如 此 进行 ， 直 到 点 George 被 一 个 数字 标记 。 

a 点 George 上 标的 数字 就 是 Alice 和 George 之 间 的 距离 。 





























像 这 样 对 计算 步 台 做 出 的 非 正 式 描述 就 叫 算法 ( algorithm )， 得 名 于 19 世 纪 波 斯 数 
学 家 穆罕默德 - 伊 本 : 穆 萨 : 花 刺 子 密 。 公 元 825 年 ， 花 刺 子 密 发 表 了 《 论 印 度数 字 的 
计算 》( On the Calculation with Hindu Numerals ), 这 本 著作 的 意义 是 将 印度 的 计数 系统 推 
广 到 中 东 和 欧洲 。 书 名 的 拉丁 文 译 法 是 4lgoritmi de numero Indorum, Al-Khwarizmi ( 花 
刺 子 密 ) 在 拉丁 语 里 变 成 了 Algoritmi， 然 后 变 成 了 今天 的 术语 algorithm。 


























上 述 算法 能 用 差不多 50 万 步 计算 出 Alice 和 George 的 距离 。 要 找到 所 有 敌 友 国 居 民 
中 任意 一 对 之 间隔 了 多 远 ， 我 们 需要 更 高 明 的 算法 。Floyd-Warshall 算 法 能 用 大 概 8 万 
亿 步 就 计算 出 所 有 这 些 距 离 。 可 能 你 觉得 1 万 亿 这 个 数 听 起 来 挺 大 ， 但 如 今 的 个 人 计 
算 机 每 秒 都 能 执行 几 十 亿 个 操作 。 敌 友 国 理工 学 院 的 机 器 在 几 分 钟 内 就 计算 出 了 全 部 
国民 之 间 的 分 隔 距 离 。 科 学 家 们 发 现 本 国 的 平均 分 隔 距 离 比 6 要 稍 大 一 点 ， 尺 管 有 些 
人 组 成 的 朋友 圈 非 常 孤立 ， 里 面 的 人 和 圈 外 的 人 都 不 是 朋友 。 




















我 们 可 不 能 低估 刚才 发 生 的 事情 的 意义 。 当 然 研究 者 可 以 编程 遍历 所 有 路 径 ， 找 
出 其 中 连接 Alice 和 George 且 最 短 的 一 条 , 但 这 样 做 可 能 要 检查 的 路 径 太 多 了 ， 导致 程 
序 没 法 在 合理 时 限 内 跑 完 。 然 而 采用 某 种 更 简单 的 算法 ， 他 们 能 在 一 秒 内 算出 Alice 
和 George 之 间 的 距离 ， 并 且 在 几 分 钟 内 算出 敌 友 国 居民 中 任意 一 对 之 间 的 距离 。 





























3.3 "EHE 




















在 敌 友 国 ， 一 段 美满 的 姻缘 几乎 完全 取决 于 双方 是 否 是 很 好 的 朋友 。 然 而 敌 友 关 
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系 的 分 布 完全 没有 规律 ， 有 些 幸运 儿 可 能 碰巧 找到 了 合适 的 人 选 ， 剩 下 的 人 则 很 难 找 
到 一 个 好 伴 但 。 








敌 友 国 的 研究 者 意识 到 可 以 用 他 们 的 数据 来 为 社会 服务 ,让 成 功 婚姻 的 数量 最 大 
于 是 他 们 在 网 站 上 招募 了 200 个 志愿 者 ， 其 中 一 半 是 男性 ， 一 半 是 女性 ， 所 有 人 
都 是 异性 恋 。 他 们 想 尽 可 能 多 地 为 合适 的 男女 牵线 搭桥 。 
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一 共 需 要 搜索 多 少 种 可 能 性 呢 ? 和 第 一 个 男性 配对 的 女性 人 选 有 100 个 可 能 。 
做 出 选择 后 剩 下 的 99 个 女性 可 能 和 第 二 个 男性 配对 , 然后 是 98 个 女性 和 第 三 个 男性 
配对 ， 如 此 等 等 。 这 样 所 有 的 可 能 数 是 100 乘 以 99 乘 以 98 乘 以 …… 乘 以 2 乘 以 1， 这 
个 值 被 称 为 “100 的 阶乘 ", 写作 100!, 这 个 数 有 158 位 ， 比 googol 还 大 。googol 这 个 
名 字 是 数学 家 爱德华 . 卡 斯 纳 九 岁 的 侄子 起 的 ， 当 时 卡 斯 纳 想 给 1 后 边 跟 100 个 0 的 
数 起 名 。 





























互联 网 公司 Google 得 名 于 对 googol 的 错误 拼写 ， 它 是 对 该 公司 搜索 引擎 所 处 理 
的 海量 数据 的 一 个 形象 但 非常 不 准确 的 表示 。 互 联网 这 种 庞然大物 ( 实际 上 无 法 测 
量 它 有 多 大 ) 所 包含 的 信息 量 无 论 分 得 多 细 ， 都 还 远 远 达 不 到 googol 这 个 数量 级 。 
所 以 ， 即 使 动用 全 部 的 计算 机 算 到 地 老 天 荒 ， 也 不 可 能 搜索 googol 数 量 级 的 信息 ， 
更 别提 100! 了 。 

















然而 敌 友 国 研究 者 还 是 能 找到 成 功 配对 数 的 最 大 可 能 值 ， 只 需 换 一 个 高 明 的 算法 
即 可 。 下 边 这 张 图 显示 了 哪些 男女 志愿 者 是 朋友 关系 。 











Arthur Eve 
Bob Felicity 
Carl Gail 

David Helen 





图 3-2” 敌 友 国 的 男女 们 























让 我 们 看 看 谁 跟 谁 可 能 是 天 作 之 合 。 首 先 我 们 把 Arthur 和 Eve 凑 成 一 对 。Bob 和 
Felicity 这 对 朋友 还 没有 在 一 起 ， 让 我 们 促成 他 俩 ， 同 样 祝 福 Carl 和 Gail。 现 在 我 们 有 
了 一 张 新 图 ， 虚 线 表 示 我 们 做 出 的 配对 选择 。 
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Arthur Eve 
Bob Felicity 
Carl Gail 

David Helen 





图 3-3 ”部 分 配对 的 男女 们 




















这 下 不 存在 能 够 配对 的 朋友 了 ， 这 是 可 能 的 配对 结果 中 最 好 的 吗 ? 不 一 定 。 


David gA H5, 但 他 和 Felicity 是 朋友 , 而 Felicity 和 Bob 在 一 起 。 Bob 和 Gail 是 朋友 (但 
我 们 没有 撮合 他 俩 )。Gail 和 Carl 是 一 对 。Carl 和 没有 伴 儿 的 Helen 是 朋友 。 如 果 我 们 拆散 
Bob 和 Feliciy， 再 坏 了 Carl 和 Gail 的 好 事 ， 然 后 重新 配对 ， 那 么 这 下 所 有 人 都 成 功 配对 了 。 














Arthur 





图 3-4 ”全 部 配对 的 男女 们 


第 二 张 图 中 连接 两 个 人 的 实 线 和 虚线 的 序列 ， 叫 做 增 广 路 径 (augmenting path ), 
它 可 以 用 来 增 大 配对 的 数量 。1957 年 ， 克 劳 德 ， 伯 杰 证 明 任何 未 达到 最 大 可 能 配对 数 
的 匹配 方式 都 对 应 一 个 增 广 路 径 。 政 友 国 理工 学 院 的 计算 机 科学 家 写 了 一 个 简单 的 算 
法 来 找到 这 些 增 广 路 径 ， 结 果 让 参加 实验 的 98% 的 人 都 成 功 配对 。 
































不 久 以 后 ， 敌 友 国 最 高 法 院 裁定 ， 人 允许 同性 结婚 。 于 是 学 院 在 网 站 上 张贴 启事 ， 
招募 所 有 性 别 取 向 的 志愿 者 。 这 下 关系 图 更 复杂 了 ， 出 现 了 许多 彼此 交 秋 的 三 角 恋 爱 
关系 ， 如 下 所 示 。 











John | ————————— Larry 


Mark 


Nancy 
图 3-5 打破 传统 的 男男女女 
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这 导致 寻找 增 广 路 径 的 简单 算法 不 好 用 了 。 研 究 者 转 而 求助 于 杰克 埃 德 莹 兹 的 
工作 。 在 1965 年 , 埃 德 蒙 效 写 了 一 篇 标题 很 文艺 的 论文 路径、 树木 与 花 朱 ”( Path, Trees 
and Flowers )， 里 面 介绍 了 一 种 稍为 复杂 的 方法 ， 能 够 在 广义 好 友 关 系 图 中 找 出 增 广 
路 径 。 敌 友 国 理工 学 院 采 用 埃 德 蒙 北 的 思路 ， 从 而 能 够 让 97% 的 参与 第 二 个 实验 的 人 
找到 合适 的 伴 但 。 














“路 径 、 树 木 与 花 打 ”中 的 思想 ， 除 了 能 为 解决 广义 好 友 关 系 图 中 的 配对 问题 提供 
一 种 有 效 的 方法 ， 还 有 更 大 的 影响 。 埃 德 蒙 兹 的 算法 为 100 个 人 找到 最 佳 匹 配 需 要 大 概 
1004 个 计算 步骤 。 对 于 今天 的 计算 机 , 计算 100* ( 即 1 亿 ) 次 一 点 也 不 费劲 ， 而 更 原始 的 
穷 举 方法 大 概 需 要 的 计算 步骤 数 是 2 后 边 跟 78 个 0。 埃 德 蒙 兹 在 论文 里 还 写 了 很 多 题 外 
W, 探讨 高 效 算法 的 本 质 。 他 意识 到 不 存在 能 够 完全 抓 住 “效率 ”直观 概念 的 严格 定义 ， 
于 是 他 试 着 提出 自己 对 高 效 的 见解 , 即 存在 一 个 计算 方法 , 它 解决 这 种 规模 的 问题 所 花 
费 的 时 间 是 “算术 级 别 的 ”， 比 如 100'、100: 或 1002。 后 来 这 一 类 型 的 问题 有 了 另 一 个 
人 们 更 为 熟知 的 名 字 一 一 P (代表 polynomial， 多 项 式 级 别 的 ， 它 代替 了 埃 德 蒙 效 的 “ 算 
数 级 别 的 ” )， 人 们 用 它 来 指 代 那 些 可 以 高 效 解决 的 问题 。 这 就 是 PINP 问 题 中 P 的 一 面 。 























3.4 团 问 题 





敌 友 国 理工 学 院 的 一 个 社会 学 教授 想 做 一 个 实验 ,为 此 需要 找到 彼此 互 为 朋友 的 
50 个 居民 。 她 自己 办 不 到 ， 就 向 几 个 计算 机 科学 家 请 教 这 个 问题 ， 他 们 说 手头 刚好 有 
哪些 人 是 朋友 的 数据 。“ 找 50 个 互 为 朋友 的 人 组 成 的 团 是 吧 ， 应 该 没 问 题 。” 一 个 计算 












































但 是 有 问题 ， 而 且 是 个 很 难 的 问题 。 从 敌 友 国 里 挑 出 50 个 人 的 不 同方 案 的 个 数 ， 
是 一 个 151 位 的 天 文 数 字 ， 根 本 不 可 能 逐个 检查 。 研 究 者 们 为 此 想 尽 了 办 法 ， 比 如 他 
们 意识 到 ， 如 果 一 个 人 拥有 朋友 的 数量 不 到 50 个 ,那么 这 个 人 不 可 能 在 一 个 50 人 的 团 
里 。 即 便 如 此 ， 他 们 绞 尽 脑汁 ， 却 连 25 个 互 为 朋友 的 人 都 找 不 出 来 ， 而 且 也 不 能 有 效 
证 明 整 个 敌 友 国 不 存在 50 人 的 团 。 


























就 在 他 们 想 放 弃 的 时 候 ， 有 一 个 研究 生 说 :“ 不 是 有 个 阿尔 法 会 吗 ? ”阿尔 法 会 
( Alpha Society ) 是 一 个 富有 传奇 色彩 的 、 半 地 下 社会 组 织 ， 据 说 里 边 人 人 都 是 朋友 。 
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计算 机 科学 家 设法 找到 了 50 个 阿尔 法 会 会 员 的 名 字 (幸好 这 个 组 织 只 是 “ 半 地 下 ”)。 
有 了 这 50 人 的 名 单 ， 就 只 要 检验 1225 对 人 是 不 是 朋友 就 可 以 了 。 结果 他 们 真 的 每 两 个 
人 都 是 朋友 ,这 让 计算 机 科学 家 们 惊讶 不 已 ， 而 阿尔 法 会 会 员 们 表示 淡定 。50 个 互 为 
友人 组 成 的 团 就 这 样 被 找到 了 。 





























3.5 AHJU” 


让 我 们 看 看 一 个 求解 简单 的 问题 ， 怎 样 经 过 一 点 小 小 的 改动 ， 就 变 成 一 个 非常 难 
求解 的 问题 。 








敌 友 国 的 小 孩子 们 玩 一 种 叫 “ 递 棍 儿 ”的 游戏 。 他 们 把 一 个 小 棍子 传 来 传 去 。“ 递 ” 
的 意思 是 在 把 棍子 从 一 个 孩子 传 到 男 一 个 时 ， 两 个 人 一 起 把 它 握 住 。 


























规则 有 两 条 


只 能 给 你 的 朋友 递 棍 儿 ; 
Deeds 须 递 一 次 棍子 ， 且 只 能 递 一 次 。 


假设 5 个 小 孩 在 玩 这 个 游戏 。 


从 Barbara 开 始 , 她 把 棍子 递 给 Eric, Eric 递 给 Alex, 然后 棍子 依次 经 过 Cathy、 Eric, 
最 终 被 递 给 David， 游 戏 成 功 结 


Alex 
David 
Barbara 
Eric 
Cathy m ad 
图 3-6 “孩子 们 








玩 了 几 次 孩子 们 很 快 发 现 游戏 能 成 功 结束 的 前 提 是 , 拥有 朋友 个 数 为 奇数 的 人 不 能 
超过 两 个 : 如 David 和 Barbara 分 别 有 1 个 朋友 ， 是 奇数 ， 而 Cathy 和 Alex 分 别 有 2 个 和 4 个 
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朋友 , 是 偶数 。 为 什么 呢 ? 因为 除了 第 一 个 和 最 后 一 个 人 , 其 他 人 接 棍子 的 次 数 和 把 棍 
子 递 给 朋友 的 次 数 必 须 相 等 ， 所 以 这 些 人 中 间 的 每 个 人 经 手 棍子 的 次 数 应 该 是 偶数 。 
如 果 每 个 孩子 都 有 偶数 个 朋友 , 那么 游戏 也 能 玩 成 ， 只 要 保证 开始 和 结束 时 是 同 
一 个 人 就 可 以 了 。 
比如 孩子 们 可 以 这 样 传 棍子 : 从 Alex 开 始 ， 棍 子 依次 经 过 Eric、David、Barbara、 
Eric、Cathy， 最 终 回 到 Alex 手 上 。 


Alex 


David 


Barbara 


Eric 


图 3-7 ”每 个 孩子 都 有 偶数 个 朋友 


“ 弟 棍 儿 ” 的 灵感 来 自 19 世 纪 的 一 个 著名 难题 。 在 普鲁士 的 哥 尼斯 堡 ( 今 俄 罗斯 
加 里 宁 格 勒 ) 有 七 座 桥 横 跨 于 普 雷 格 尔 河上 ， 请 看 这 张 老 地 图 。 




















图 3-8 SJETE 


哥 尼斯 堡 的 市 民 想 知道 能 否 有 一 条 路 线 跨 过 每 座 桥 一 次 , 并且 只 跨 过 一 次 。1735 
年 ， 著 名 的 数学 家 莱 昂 哈 德 ， 欧 拉 着 手 解决 这 个 问题 ， 他 画 了 一 张 图 。 
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和 “ 递 棍 儿 ” 游 戏 中 的 孩子 们 不 同 的 是 , 北 区 和 岛 区 、 岛 区 和 南 区 之 间 都 有 多 重 
的 “友谊 ”， 即 桥梁 。 然 而 原理 是 一 样 的 ， 欧 拉 证 明 ， 没 有 人 能 将 每 座 桥 跨 过 并 且 只 
跨 过 一 次 ， 因 为 四 块 地 区 都 有 奇数 条 桥梁 与 其 他 地 区 相连 。 


NS 


图 3-9” 欧 拉 的 难题 



































a 

















因为 源 于 欧 拉 和 哥 尼 斯 堡 七 桥 难 题 ,“ 递 棍 儿 ”游戏 的 成 功 完成 方式 叫做 欧 拉 回 
路 。 玩 的 人 比较 多 时 ， 完 成 游戏 的 方式 可 能 有 很 多 种 ， 但 孩子 们 可 以 很 容易 地 判断 能 
不 能 玩 成 ， 只 要 数 数 有 几 个 人 的 朋友 个 数 是 奇数 就 行 了 。 

随 着 敌 友 国 的 孩子 们 渐渐 长 大 ， 他 们 觉得 “ 递 棍 儿 ” 太 简 单 了 ,没劲 。 于 是 他 们 
稍微 改 了 一 下 规则 ， 新 游戏 起 名 为 “ 递 棍 儿 2”( 真 没 创 意 )。 修改 后 的 规则 如 下 : 























1. 只 能 给 你 的 朋友 递 棍 儿 ; 
2. 棍子 必须 上 且 只 能 每 个 人 经 手 一 次 ， 第 一 个 递 出 棍子 的 人 除外 ， 因 为 棍子 最 终 要 
还 到 他 手 里 。 








以 下 边 这 张 朋 友 关 系 图 为 例 ，David 把 棍子 递 给 Barbara， 然 后 棍子 依次 经 过 Eric、 
Alex、Cathy， 最 终 递 回 David 手 上 。 





Alex 
David 


Barbara 


Eric 


图 3-10 ”可 以 完成 的 “ 递 棍 儿 ” 
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而 在 接 下 来 这 张 图 里 ， 孩 子 们 发 现 不 可 能 完成 “ 递 棍 儿 2”。 
Alex 


David 
Barbara 


Eric 


图 3-11 不 可 能 完成 的 “ 递 棍 儿 ” 





由 于 规则 变 简 单 了 ， 孩 子 们 以 为 “ 递 棍 儿 2” 会 更 容易 解决 。 但 是 当 人 数 变 得 较 
多 时 ,“ 递 棍 儿 2” 的 难度 陡然 上 升 。1857 年 ， 数 学 家 威廉 ， 罗 恩 ' 哈密 顿 发 明了 一 个 
叫 Icosian 的 数学 游戏 。 我 们 可 以 用 “ 递 棍 儿 2” 来 描述 它 的 玩法 ， 为 了 让 图 更 简单 ， 
我 们 把 每 个 人 用 名 字 的 首 字母 代替 。 





























图 3-12 ”Icosian 难 题 











Icosian 游 戏 来 自 正 十 二 面体 ， 即 一 个 有 十 二 个 平面 的 球 。 





如 果 顶 点 代表 敌 友 国 的 人 ,每 条 边 代 表 一 对 朋友 之 间 的 关系 ， 就 会 得 到 上 面 那 张 
好 友 关 系 图 。 


为 了 纪念 Icosian 游 戏 的 发 明 者 ,“ 递 棍 儿 2” 游 戏 的 成 功 完 成 方式 叫做 哈密 顿 回路 。 
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图 3-13 十 二 面体 


3.6 JT 


敌 友 国政 府 颁 布 了 一 个 新 法 案 ， 要 求 所 有 公民 为 了 城市 的 美观 ， 必 须 把 自家 的 房 
子 刷 成 和 所 有 邻居 的 房子 不 一 样 的 颜色 ， 无 论 邻 里 之 间 是 敌 是 友 。 很 多 人 表示 抗议 ， 
说 这 是 强制 让 民众 白花 钱 、 做 苦 工 。 后 来 政府 同意 用 公共 资金 为 居民 刷 房 报销 全 款 ， 
但 有 一 个 条 件 : 刷 什 么 颜色 要 由 政府 来 定 。 












































由 于 要 买 的 涂料 数量 巨大 ， 政 府 职能 机 构想 尽 可 能 减少 购买 的 涂料 颜色 的 种 类 。 
少 用 一 种 颜色 就 能 省 下 几 百 万 美元 。 政 府 给 敌 友 国 理工 学 院 氢 了 一 笔 钱 ， 让 他 们 找到 
最 少 需要 几 种 颜色 的 涂料 才能 保证 所 有 相 邻 的 房子 都 有 不 同 的 颜色 。 














敌 友 国 每 家 最 多 有 12 个 邻居 。 所 以 最 容易 想到 和 实现 的 方案 需要 13 种 颜色 : 每 个 
邻居 刷 一 种 不 同 的 颜色 ， 然 后 中 间 的 房子 刷 第 13 种 颜色 。 但 敌 友 国 的 研究 者 觉得 他 们 
还 能 做 得 更 好 。 




















1852 年 ， 南 非 数 学 家 弗朗西斯 ， 格 思 里 在 为 奖 国 各 和 郡 的 地 图 填 色 时 ， 猜 想 是 和 否 只 
用 四 种 颜色 ， 就 足够 让 所 有 地 图 上 每 两 个 接壤 的 地 区 有 不 同 的 颜色 。 当 时 很 多 数学 家 
都 考虑 了 格 思 里 提出 的 问题 ， 接 着 在 1879 年 和 1880 年 出 现 了 两 个 四 色 问 题 的 “证 明 ”， 
分 别 由 阿尔 弗 雷 德 . 青 普 以 及 彼得 . 泰 特 发 表 。11 年 后 两 个 证 明 都 被 发 现 有 致命 错 
误 ， 在 之 后 几乎 一 个 世纪 的 时 间 ， 这 个 问题 都 未 能 得 到 解决 。 
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1976 年 ， 肯 尼斯 阿 佩 尔 和 沃 尔 夫 内 . 哈 表 终于 给 出 了 四 色 问 题 的 证 明 ， 但 他 们 
使 用 了 一 种 非常 有 争议 的 技术 。 证 明 过 程 需要 用 一 个 计算 机 穷 举 所 有 可 能 的 情况 来 支 
持 他 们 的 论点 。 传 统 数 学 家 不 相信 这 样 的 证 明 ， 因 为 它 不 能 完全 用 人 的 思维 来 检验 。 
但 是 几 十 年 过 去 了 ， 人 们 没有 找到 阿 佩 尔 - 哈 肯 证 明 中 有 任何 错误 ， 如 今 大 多 数 人 都 
相信 ， 四 种 颜色 足够 为 所 有 的 地 图 填 色 。 

















四 就 是 极限 了 吗 ? 三 种 颜色 够 不 够 填 满 所 有 地 图 ? 不 够 , 来 看 内 华 达 州 和 它 接 埃 


的 州 。 


爱 达 荷 州 






俄勒冈 州 





加 利 福 尼 亚 州 


亚利桑那 州 





图 3-14 ”内 华 达 州 





加 利 福 尼 亚 州 、 俄 勒 四 州 、 爱 达 荷 州 、 犹 他 州 和 亚利桑那 州 ， 这 几 个 州 在 内 华 达 
州 外 面 围 成 一 圈 。 由 于 这 个 圈 包 含 奇 数 个 州 (5 个 )， 需 要 至 少 三 种 颜色 来 填充 它们 ; 
如 果 只 有 两 种 颜色 ， 比 如 绿 和 蓝 ， 加 利 福 尼 亚 州 涂 绿色 ， 与 之 接壤 的 俄勒冈 州 必然 是 
蓝 色 ,然后 爱 达 答 州 必须 是 绿色 ， 犹 他 州 是 蓝 色 。 现 在 ， 亚 利 又 那州 分 别 与 绿色 的 加 
利 福 尼 亚 州 和 蓝 色 的 犹他 州 接壤 ， 所 以 它 既 不 可 以 是 绿色 ,也 不 能 是 蓝 色 。 所 以 我 们 
至 少 需要 三 种 颜色 一 一 蓝 、 绿 和 黄 ， 来 填充 这 五 个 州 。 



































内 华 达州 与 五 州 分 别 接壤 ,那么 它 不 能 填 蓝 、 绿 或 黄 这 三 种 颜色 。 所 以 我 们 需要 
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第 四 种 颜色 一 一 红 ， 来 为 内 华 达 州 上 色 。 





有 了 基于 四 色 定 理 的 证 明 的 高 效 算法 ， 就 可 以 很 快 为 任意 地 图 涂 上 四 种 颜色 。 于 
是 敌 友 国 的 研究 者 找到 了 用 四 种 颜色 给 所 有 房子 刷 漆 的 方法 , 保证 了 相 邻 房子 的 颜色 
不 同 。 政 府 又 敦促 学 院 找到 只 用 三 种 颜色 涂料 的 方法 。 恰 巧 敌 友 国 没有 邻居 个 数 为 奇 
数 的 房子 ， 所 以 研究 者 没 办 法 直接 排除 只 用 三 种 颜色 的 方法 存在 的 可 能 性 。 





























计算 机 科学 家 们 几经 尝试 , 最 终 放弃 了 。 他们 向 政府 报告 找 不 到 只 用 三 种 颜色 的 
涂 色 方 案 。 政 府 不 得 不 使 用 四 种 颜色 的 方案 粉刷 所 有 房子 。 天 友 国 的 计算 机 科学 家 们 
将 来 在 申请 政府 津贴 时 会 遇 到 更 多 困难 。 


37 分 组 


敌 友 国 小 学 的 老师 想 把 500 个 学 生 分 成 两 组 。 每 个 人 都 想 和 朋友 在 一 起 ， 所 以 老 
师 想 尽 可 能 避免 把 一 对 好 友 分 到 两 个 组 去 。 让 我 们 用 “ 递 棍 儿 ”游戏 中 的 那 张 好 友 关 


Alex 
David 
Barbara 
Eric 
图 3-15 “小 学 




















最 好 的 分 组 方法 是 把 Alex 和 Cathy 放 在 一 组 ，Barbara、David 和 Eric 在 另 一 组 ， 这 
样 只 拆散 了 两 对 好 友 ，Alex 一 Eric 以 及 Cathy 一 Eric。 不 存在 只 拆散 一 对 好 友 的 方案 。 


敌 友 国 小 学 的 校长 癌 学 院 求助 。 有 很 多 有 效 的 方法 可 以 解决 这 个 问题 ， 它 被 称 为 


最 小 割 问 题 ， 因 为 老师 想 把 被 分 割 的 好 友 数 减 到 最 小 。 研 究 者 针对 这 500 个 学 生 给 出 
了 一 个 很 好 的 分 组 方案 ， 只 拆散 了 17 对 好 友 。 

















第 3 章 P 和 NP | 39 


Alex 


Cathy M di 


图 3-16 “小 学 的 分 组 





从 此 以 后 所 有 人 都 过 上 了 快乐 的 生活 。 说 “从 此 以 后 ”不 太 准 确 ， 事实 上 只 过 
了 一 天 ,老师 就 发 现 ， 把 很 多 互 为 仇敌 的 小 孩 分 到 一 组 太 粳 糕 了 ， 比 拆散 好 友 更 不 
可 取 。 于 是 校长 回 到 学 院 ， 请 研究 者 找到 一 种 把 尽 可 能 多 的 互 为 敌人 的 学 生 分 到 不 
同 组 里 的 方案 。 校长 觉得 第 一 次 的 分 组 问题 解决 得 那么 轻松 , 这 次 应 该 也 不 会 太 难 。 
校长 想 错 了 。 












































在 这 个 新 问题 里 ， 研 究 者 需要 尽 可 能 多 地 把 敌人 分 割 开 ， 这 叫做 最 大 割 问题 。 
但 是 不 像 最 小 制 问题 ,计算 机 科学 家 不 知道 哪 种 算法 能 最 大 化 被 分 割 到 两 个 组 的 仇 
BOR H o 











te sé cM REG. 5EBSRIHIT9954E THOKBIUR * 戈 麦 斯 和 大 卫 : 威廉 森 写 的 算 
法 ,找到 了 一 个 将 1321 对 敌人 分 割 到 两 个 组 的 方案 。 尽 管 没 能 找 出 最 好 的 方案 , 但 他 
们 知道 不 存在 把 1505 对 及 以 上 的 敌人 分 割 到 两 组 的 方案 。 校 长 有 点 失望 ， 他 以 为 学 院 
能 找到 最 好 的 方案 ， 但 现 有 方案 也 还 算 合理 。 从 此 以 后 所 有 人 都 过 上 了 更 加 快乐 或 更 
加 郁闷 的 生活 。 

















3.8 PA 和 NP 


让 我 们 看 看 哪些 问题 让 敌 友 国 的 研究 者 们 头疼 不 已 : 团 、 哈 密 顿 回路 (“ 弟 棍 儿 
2”)、 地 图 填 色 ， 以 及 最 大 割 。 这 些 问题 有 一 个 共性 ， 都 可 以 用 很 简单 的 方法 检查 方 
案 的 有 效 性 。 一 旦 敌 友 国 的 科学 家 找到 了 阿尔 法 会 的 成 员 ， 就 很 容易 验证 是 不 是 所 有 
成 员 之 间 都 互 为 朋友 ， 即 阿尔 法 会 成 员 组 成 的 是 一 个 团 。 孩 子 们 如 果 听 说 了 一 个 能 完 
成 “ 递 棍 儿 ”游戏 的 方法 ， 只 要 顺 着 方法 玩 一 遍 就 知道 对 不 对 。 随 便 给 出 一 个 涂 色 方 





















































40 可 能 与 不 可 能 的 边界 ，P/NP 问 题 趣 史 











案 , 政府 很 容易 检查 它 是 否 符合 相 邻 的 房子 颜色 不 同 。 在 最 后 一 个 例子 里 ， 对 于 任意 
一 个 分 组 方式 ， 校 长 只 要 数 数 有 几 对 敌人 被 分 开 就 能 判断 方案 的 好 坏 。 





这 一 类 能 够 很 快 验证 一 个 解 的 有 效 性 的 问题 ， 计 算 机 科学 家 给 它们 起 了 一 个 名 
F: NP。 如 果 你 非 想 知道 的 话 ， 这 两 个 字母 代表 nondeterministic polynomial time ( 不 
确定 性 多 项 式 时 间 )。 团 、 哈 密 顿 回路 、 地 图 填 色 和 最 大 割 都 是 NP 中 的 典型 例子 。 



























































与 之 形成 对 比 的 是 P 类 问题 ， 即 我 们 能 很 快 找到 最 优 解 的 这 些 问 题 : 最短 路径 、 
配对 、 欧 拉 回 路 〈“ 递 棍 儿 1”)， 以 及 最 小 割 。 


也 许 存 在 能 快速 找到 团 的 高 明 算 法 。 可 能 将 来 某 个 聪明 的 研究 生 能 想 出 如 何 轻松 
找 出 哈密 顿 回 路 ， 或 是 一 个 最 大 化 分 割 敌 人 到 两 个 小 组 的 快速 步 又。 也 许 团 、 哈 密 顿 
回路 、 地 图 填 色 和 最 大 割 也 是 在 P 类 问题 中 的 ， 就 像 最 短路 径 、 配 对 、 欧 拉 回 路 和 最 
小 割 一 样 。 也 许 NP 中 的 每 个 问题 都 有 一 个 快速 的 解法 ， 我 们 只 是 不 知道 而 已 。 

















这 就 是 PINP 问 题 。P = NP 意味 着 美好 世界 的 到 来 ， 每 个 NP 中 的 问题 都 对 应 一 个 
有 效 的 解法 ， 也 就 是 说 每 个 有 解 的 问题 都 能 很 快 地 验证 给 定 解 ， 并 且 快 速 地 找到 其 中 
最 优 的 解 ,与 此 相反 ,如 果 哪 怕 有 一 个 NP 中 的 问题 我 们 找 不 到 能 给 出 快速 解法 的 算法 ， 
那么 P 还 是 不 等 于 NP。 
































判 呵 P 是 否 等 于 NP 是 计算 机 科学 乃至 整个 数学 领域 最 关键 的 问题 。 许 多 人 哎 心 浙 
血 ， 试 图 找到 解决 团 、 哈 密 顿 回路 或 其 他 问题 的 好 算法 ， 可 惜 都 失败 了 。 与 此 相反 ， 
UEH P ENP ,必须 证 明 无 论 现在 还 是 将 来 , 都 不 可 能 存在 能 够 快速 找到 团 或 解决 其 
他 NP 问题 的 算法 。 如 何 证 明 一 件 事 不 可 能 做 成 ? 目前 这 两 个 研究 方向 都 没有 什么 实质 
性 进展 。 




















正 是 认识 到 了 P/NP 问 题 的 重要 性 , 克 雷 数学 研究 所 才 决 定 为 解决 它 的 人 提供 一 百 
万 美元 的 奖金 。 也 正 因为 它 无 比 关键 ， 才 促使 我 写 出 了 这 本 书 。 








3.9. 敌 友 国之 外 

















这 章 给 出 的 只 是 几 个 例子 ， 除 此 之 外 还 有 成 千 上 万 个 我 们 不 能 快速 求解 的 NP 问 
题 。 要 是 你 觉得 除了 计算 机 科学 家 和 子虚乌有 的 敌 友 国 居民 之 外 , 没有 人 会 对 P/NP 问 
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- B 


感 兴趣 ， 那 么 请 让 我 列举 一 小 部 分 来 自 其 他 学 科 领 域 的 例子 ， 我 们 同样 不 知道 下 面 
些 问 题 的 有 效 算法 。 


这 
1. 生物 学 


人 类 有 23 对 染色 体 。 每 条 染色 体 上 都 排 布 着 由 碱 基 对 组 成 的 基因 序列 , 碱 基 对 有 
四 种 ， 即 腺 味 哈 (A, adenine), MEIE (C, cytosine) SIE (G, guanine ) 和 胸 
IERIE (T, thymine )。 染 色 体 序列 可 能 以 ACTGATTACA 开 始 ， 可 能 会 很 长 。 最 短 的 
序列 有 4700 万 碱 基 对 ， 最 长 的 有 2 亿 4700 万 碱 基 对 。 当 代 DNA 测 序 技术 一 次 只 能 测定 
大 约 20 ~ 1000 个 碱 基 对 。 生 物 学 家 需要 想 办 法 把 许多 短小 的 序列 片段 拼接 成 完整 的 序 
列 。 拼接 序列 是 一 个 很 难 的 计算 问题 , 也 是 一 个 NP 问题 , 因为 如 果 我 们 提前 知道 了 要 
拼接 的 DNA 序 列 的 全 貌 ， 我 们 可 以 用 相对 较 快 的 方式 检查 某 种 拼接 方式 是 否 与 之 匹 
配 。 由 于 找 不 到 解决 这 个 NP 问题 的 有 效 算法 , 生物 学 家 需要 更 多 的 序列 才能 绘制 出 基 
因 组 图 谱 。 而 且 很 可 能 绘制 出 的 图 谱 上 有 更 多 的 空白 和 错误 。 研发 出 剪接 序列 的 最 优 
算法 将 显著 提升 基因 图 谱 的 质量 。 
































DNA 序 列 能 编码 信使 RNA (mRNA ) 的 序列 ， 后 者 负责 蛋白 质 的 表达 ， 而 蛋白 质 
则 在 组 成 生物 细胞 的 几乎 所 有 功能 中 发 挥 着 关键 性 作用 。 和 蛋白 质 执 行 何 种 功能 通常 依 
赖 于 特定 的 几何 形状 ， 而 mRNA 序列 决定 蛋白 质 如 何 折 琶 ， 从 而 具有 这 种 形状 。 和 蛋白 
质 折 又 的 计算 过 程 仍然 是 生物 学 一 大 未 解 之 恋 , 研究 P/NP 问 题 对 理解 蛋白 质 折 共有 着 
重要 的 启发 作用 ， 进 而 帮助 人 类 预防 和 抵抗 疾病 。 


























和 蛋白质 折 等 识别 C protein threading ) 是 一 种 根据 mRNA 序列 来 预测 蛋白 质 折 丢 方 
式 的 统计 学 方法 。 即 使 是 这 种 对 于 理解 蛋白 质 折 针 有 很 大 局 限 性 的 方法 ， 也 需要 解决 
困难 的 NP 问题 。 





2. 物理 学 




















寻找 物理 系统 能 量 的 最 低 值 是 一 个 NP 问题 ,物理 系统 可 以 是 相互 作用 的 磁性 粒子 
群 ， 或 是 一 堆肥 气泡 ， 等 等 。 人 们 不 知道 如 何 有 效 找到 这 些 系统 最 低 的 能 量 状 态 。 难 
道 物理 系统 不 是 总 会 最 终 达到 最 低能 量 状态 吗 ? 不 一 定 。 






































考虑 一 个 弹 珠 放置 在 如 图 3-17 所 示 的 曲面 上 。 这 个 弹 珠 最 终 停 在 3.0 处 才能 达到 最 
低热 能。 如 果 它 一 开始 处 于 1.0 位 置 ， 它 将 保持 静止 ， 除 非 推 它 一 把 。 从 中 可 以 看 出 ， 
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物理 学 系统 并 非 总 会 最 终 达到 最 低能 量 状态 。 找 到 复杂 系统 的 最 小 能 量 ， 对 于 计算 机 
和 系统 本 身 来 说 ， 都 很 困难 。 
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图 3-17 ”物理 系统 的 图 表 











量子 力学 可 能 帮 有 我 们 解决 部 分 困难 的 NP 问 题 ,而 不 是 全 部 。 这 部 分 内 容 我 们 将 在 
第 9 童 深 入 讨论 。 





3. 经 济 学 


一 个 对 冲 基 金 经 理 需要 从 许多 复杂 的 投资 工具 中 作出 选择 。 一 个 预算 有 限 的 消费 
者 走 进 超市 ， 面 对 各 种 商品 难以 取舍 。 他们 其 实 都 在 求解 困难 的 NP 计算 问题 。 由 于 人 
们 并 不 是 总 能 有 效 解决 这 些 问 题 ,通常 做 出 的 决策 都 是 次 优 的 。 市 场 上 的 这 些 计算 效 
率 低 下 对 于 我 们 的 经 济 乃 至 整个 社会 的 不 利 影响 究竟 有 多 大 ? 这 是 个 很 棒 的 问题 , 可 
惜 我 们 无 法 给 出 很 棒 的 答案 。 























约翰 :纳什 是 一 个 经 济 学 家 , 传记 图 书 《 美 丽 心灵 》( 4 Beautiful Mind ) 和 同名 
电影 都 从 一 定 程度 上 展现 了 他 的 生平 。 纳 什 获 得 ( 述 到 的 ) 诺 贝 尔 奖 ， 是 因为 他 证 
明了 个 体 间 根 据 策略 互动 时 存在 一 个 均衡 状态 ， 在 此 状态 下 所 有 个 体 采取 的 策略 经 
过 博弈 达到 均衡 ， 即 任何 一 方 改变 策略 的 做 法 ， 都 不 会 为 任何 人 带 来 利益 。 纳 什 的 
存在 性 证 明 没有 给 出 如 何 找到 这 些 策略 的 方法 , 计算 机 科学 家 目前 得 到 的 证 据 显示 ， 
找到 这 样 的 策略 可 能 是 一 个 计算 上 困难 的 问题 。 问 题 的 难度 预示 着 市 场 本 身 并 非 总 
能 找到 这 样 的 均衡 状态 ， 也 就 是 说 市 场 将 保持 持续 波动 ， 人 们 也 将 不 断 改变 策略 以 
追求 更 好 的 结果 。 
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4. 数学 


1928 年 ， 数 学 泰斗 大 卫 : 希 尔 伯 特 提 出 了 他 伟大 的 判定 性 问题 ( Entscheidungs- 
problem )， 即 能 否 找到 一 个 能 正确 判定 任意 数学 命题 真 伪 的 算法 。1931 年 库 尔 特 : WE 
德尔 证 明 ， 必 然 存在 某 些 命题 ， 它 们 根本 不 能 被 任何 公理 系统 的 集合 证 实 或 证 伪 。 受 
哥 德 尔 工作 的 影响 ， 儿 年 后 ， 阿 隆 索 . 丘 奇 和 阿兰 . 图 灵 分 别 独 立 证 明了 不 存在 满足 
判定 性 问题 要 求 的 算法 。 





但 如 果 我 们 做 出 限定 ， 即 命题 所 需 证 明 的 长 度 必须 短 到 可 以 在 一 本 很 沽 的 书 上 写 
出 来 ,这 样 有 可 能 找到 判定 算法 吗 ? 我 们 可 以 通过 计算 来 求解 这 个 问题 ， 只 要 穷 举 对 
于 给 定数 学 命题 的 所 有 可 能 的 短小 证 明 就 可 以 了 。 这 是 一 个 NP 问题 , 因为 如 果 给 定 一 
MEH, 我们 容易 判断 它 是 否 有 效 , 但 是 找到 一 个 有 效 证 明 实际 上 很 困难 。 这 也 是 为 
什么 数学 家 能 通过 巧妙 地 证 明 某 些 数学 命题 而 博得 声誉 的 原因 。 



































有 时 候 找 出 让 某 些 形式 简单 的 逻辑 表达 式 为 真 的 方法 都 很 困难 。 对 这 个 问题 的 研 
究 直 接 促 成 了 一 个 能 将 大 部 分 NP 问 题 都 联系 起 来 的 理论 的 形成 。 我 们 在 下 一 章 讲 讲 这 
个 故事 。 











3.10 Icosian 游 戏 的 一 个 解 
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图 3-18 ”Icosian 的 解 


NP 中 最 难 的 问题 


心理 学 家 以 数学 家 为 研究 对 象 做 了 一 个 实验 。 把 数学 家 关 在 一 个 小 木屋 
里 ， 地 上 放 一 些 引 火 物 、 一 张 桌 子 ， 桌 子 上 有 一 桶 水 。 然 后 心理 学 家 点 着 了 
地 上 的 引火 物 。 数 学 家 提起 桌 上 的 水 桶 把 火 扑 灭 了 。 

到 目前 为 止 一 切 正常 。 心 理学 家 再 次 进行 实验 , 还 是 把 数学 家 关 在 那个 有 
桌子 、 水 桶 和 引火 物 的 小 屋 里 , 但 这 次 ,水桶 是 放 在 地 上 的 ,靠近 那 堆 引火 物 。 
然后 心理 学 家 又 放 了 火 。 数 学 家 提起 水 桶 ,把 它 放 到 桌子 上 ， 然 后 就 等 着 。 心 
理学 家 和 同事 们 好 容易 才 把 数学 家 及 时 从 即将 烧 塌 的 小 木屋 里 救出 来 。 

心理 学 家 问 数学 家 :“ 为 什么 不 像 上 次 一 样 把 火 扑 灭 ? ”数学 家 回答 : “我 
已 把 问题 归 约 到 一 个 之 前 解决 过 的 情形 。 

一 一 一 个 老生 常 谈 的 数学 笑话 


4.1 第 一 个 NP 完全 问题 


汤姆 . 赫 尔 在 1970 年 担任 多 伦 多 大 学 计算 机 科学 系 的 主任 ,他 想 聘用 斯 蒂 芬 ， 库 
克 ， 当 时 加 州 大 学 伯克利 分 校 刚刚 拒绝 了 库 克 的 终身 教授 职位 申请 。 库 克 喜欢 帆 板 运 
动 ， 于 是 赫 尔 带 他 到 安 大 咯 湖 玩 ， 给 他 展示 在 多 伦 多 附近 也 能 进行 帆 板 运动 ， 和 旧 金 
山 湾 是 一 样 的 。 这 个 小 伎俩 奏效 了 ,斯 带 芬 ， 库 克 于 1970 年 秋天 加 入 了 多 伦 多 大 学 的 
教 席 。 当 年 的 赫 尔 真 可 谓 慧 眼 识 珠 ， 因 为 在 那 之 后 不 久 ， 库 克 就 成 为 加 拿 大 最 著名 的 
计算 机 科学 家 。 


















































库 克 研究 逻辑 学 和 计算 机 科学 的 联系 。 那 年 秋天 ， 他 向 即将 在 来 年 五 月 召开 的 第 
三 届 ACM 计 算 理 论 年 会 (ACM Symposium on the Theory of Computing, STOC ) 提交 
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了 一 篇 论文 。 这 篇 论文 最 初 的 结论 已 经 被 遗忘 了 ， 不 过 它 在 当时 引起 了 足够 的 兴 

被 安排 在 会 上 宣读 。 在 准备 会 议 期 间 ， 库 克 重 写 了 论文 以 加 入 最 新 的 工作 成 果 ， 而 这 
篇 名 为 “理论 证 明 过 程 的 复杂 度 ”( The Complexitiy of Theorem-Proving Procedures ) 
的 论文 ， 将 首次 把 PINP 问 题 呈 现在 世人 面前 ， 进 而 改变 历史 。 























为 更 好 理解 库 克 的 论文 ， 让 我 们 回头 看 看 上 一 章 的 团 问题 。 团 是 一 群 互 为 朋友 的 
敌 友 国 居 民 。 在 下 面 这 张 好 友 关 系 图 中 ，Alex、Cathy 和 Eric 是 一 个 团 , 而 Alex、David 
和 Eric 则 不 是 ， 因 为 Alex 和 David 是 敌人 而 非 朋友 。 














Alex 
David 
Barbara 
Eric 
图 4-1 Hi 





你 可 能 记得 , 在 敌 友 国有 一 个 半 地 下 社会 组 织 叫 阿尔 法 会 ， 据 说 里 面 的 成 员 都 互 
为 朋友 ,也 就 是 说 他 们 构成 一 个 很 大 的 团 。 假设 阿 尔 法 会 真 的 是 一 个 团 ， 我 们 能 否 从 
上 面 的 好 友 关 系 图 看 出 一 些 端倪 ? 首先 不 能 排除 任何 一 个 人 是 阿尔 法 会 成 员 的 可 能 。 
Alex 可 能 在 阿尔 法 会 ，David 也 有 可 能 。 但 是 Alex 和 David 不 可 能 同时 在 阿尔 法 会 ， 
为 他 们 是 敌人 。 所 以 要 么 Alex 不 在 阿尔 法 会 ， 要 么 David 不 在 。 让 我 们 把 这 个 逻辑 表 
达 式 写 下 来 。 






































Alex not in Alpha Society OR David not in Alpha Society 


这 里 的 oR 不 具有 排斥 性 ， 即 有 可 能 Alex 和 David 都 不 在 阿尔 法 会 。 由 于 Alex 和 
Barbara 是 敌人 ， 所 以 我 们 也 知道 这 两 个 人 不 可 能 同时 在 会 里 : 








Alex not in Alpha Society OR Barbara not in Alpha Society 


这 两 个 逻辑 表达 式 必 须 同 时 为 真 ， 所 以 我 们 有 : 





(Alex not in Alpha Society OR David not in Alpha Society) AND 
(Alex not in Alpha Society OR Barbara not in Alpha Society) 











46 | 可 能 与 不 可 能 的 边界 : P/NP 问 题 趣 史 


既然 Barbara 和 David 是 朋友 ， 他 们 可 能 都 在 阿尔 法 会 ， 然 而 这 个 逻辑 与 上 述 表达 
式 并 不 冲突 。 把 完整 的 关系 图 用 逻辑 表示 出 来 ， 我 们 得 到 : 





Alex not in Alpha Society OR David not in Alpha Society) AND 
Alex not in Alpha Society OR Barbara not in Alpha Society) AND 
David not in Alpha Society OR Cathy not in Alpha Society) AND 
Cathy not in Alpha Society OR Barbara not in Alpha Society) 


( 
( 
( 
( 
如 果 Alex 、Cathy 和 Eric 在 阿尔 法 会 ， 而 Barbara 和 David 不 在 ， 表 达 式 为 真 ， 因 为 
每 个 oR 项 中 都 因 存 在 不 是 会 员 的 人 而 得 到 满足 。 然 而 , 如 果 Alex、David 和 Eric 在 会 中 ， 
则 表达 式 为 假 : (Alex not in Alpha Society OR David not in Alpha Society) 


这 部 分 不 满足 ， 因 为 Alex 和 David 都 在 会 中 。 








表达 式 很 好 地 表达 了 团 问 题 。 当 且 仅 当 阿 尔 法 会 的 成 员 们 组 成 一 个 团 时 ， 表 达 式 
为 真 。 





我 们 可 以 为 敌 友 国 的 2 万 居民 生成 一 个 类 似 的 逻辑 表达 式 ， 将 它 简写 为 ep。e 可 能 
很 长 ， 有 几 百 万 个 字符 ， 但 是 计算 机 能 很 容易 地 存 下 它 。 如 果 阿 尔 法 会 真是 一 个 团 ， 
则 表达 式 为 真 。 


























我 们 有 另 一 个 表达 式 g50， 它 在 阿尔 法 会 有 至 少 50 个 成 员 时 为 真 。 我 不 想 具 体 讲 
如 何 写 出 g50， 它 的 构造 方法 和 最 早 的 电子 计算 机 做 加 法 的 方式 是 一 样 的 。 























如 果 把 两 个 表达 式 结合 起 来 ， 我 们 就 得 到 (y50 AND 6) ， 它 在 “阿尔 法 会 是 一 个 
团 ， 且 至 少 有 50 个 成 员 ” 时 为 真 。 反 过 来 说 ， 如 果 阿 尔 法 会 令 (Vy50 AND o) E, JB 
么 它 是 一 个 至 少 有 50 个 元 素 的 团 。 












































假设 我 们 有 一 个 快速 算法 ， 它 能 告诉 我 们 给 定 的 逻辑 表达 式 是 否 能 被 满足 。 如 果 
我 们 给 它 (?50 AND 9) ， 然 后 它 回答 :“ 是 的 ，(850 AND @) 可 以 被 满足 。 则 敌 友 国 
存在 一 个 50 人 的 团 。 如 果 (vy50 AND @) 不 可 以 被 满足 ， 则 那里 不 存在 这 样 的 团 。 解 决 
了 这 个 可 满足 性 问题 ， 你 就 能 解决 团 问题 。 





























我 们 刚刚 描述 了 一 个 计算 机 科学 中 最 关键 的 概念 : 归 约 。 我 们 把 寻找 团 的 问题 归 
约 到 检查 逻辑 表达 式 的 可 满足 性 的 问题 。 现 在 只 要 我 们 有 解决 可 满足 性 问题 的 算法 ， 
就 可 以 通过 很 容易 的 变换 ， 得 到 团 问 题 的 求解 算法 。 团 问题 的 求解 至 少 和 可 满足 性 的 
求解 一 样 容易 。 如 果 可 满足 性 是 容易 求解 的 ， 那么 团 问题 也 是 。 如 果 团 问题 没有 有 效 
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解法 ， 那 么 可 满足 性 问题 也 没有 。 





能 归 约 到 可 满足 性 问题 的 不 仅 是 团 问题 , 而 且 还 包括 我 们 前 面 讨论 过 的 其 他 NP 
问题 ， 包 括 旅 行 推销 员 问题 、 哈 密 顿 回 路 、 最 大 割 和 地 图 填 色 问题 。 事 实 上 ， 斯 蒂 
芬 . 库 区 证 明了 NP 中 的 每 一 个 问题 都 能 通过 某 种 方式 归 约 到 可 满足 性 问题 。 解 决 了 
可 满足 性 问题 ,你 就 能 解决 所 有 的 NP 问题 。 如 果 你 有 解决 可 满足 性 的 有 效 算法 ,我 
们 就 能 快速 解决 所 有 容易 检查 特定 解 有 效 性 的 问题 ， 也 就 是 说 证 明了 P= NP 。 只 要 
你 有 一 个 解决 可 满足 性 的 有 效 算法 ， 那 么 克 雷 研究 所 提供 的 几 百 万 美元 奖金 就 是 你 
的 了 。 










































































1971 年 5 月 4 日 ， 在 当时 的 俄亥俄 州 榭 柯 高 地 斯 托 弗 的 萨 默 塞 特 酒店 召开 的 STOC 
E, 斯蒂芬. 库 克 宣读 了 自己 的 论文 。 




















结果 表明 , 可 满足 性 问题 可 以 作为 一 个 相对 有 用 但 尚未 存在 有 效 计算 方法 的 待 选 
课题 来 研究 ,并 且 我 认为 值得 投入 更 多 精力 来 证 明 这 个 猜想 。 找 到 它 的 证 明 将 可 能 带 
来 重大 的 突破 。 





P/NP 问 题 从 此 诞生 了 。 


42 ”21 个 问题 











库 克 的 论文 刚刚 发 表 时 ， 尽 管 结果 的 重要 性 得 到 了 肯定 , 但 也 没有 立即 改变 学 术 
研究 的 方向 。 毕 竞 对 可 满足 性 问题 感 兴趣 的 人 不 多 , 并 且 大 家 对 NP 问题 还 不 熟悉 。 斯 
带 芬 . 库 克 其 至 没有 在 论文 中 提 到 NP 这 个 缩写 , 而 用 了 它 的 全 名 “不 确定 性 多 项 式 时 
间 ”( nondeterministic polynomial time )。 但 不 久 以 后 , 情况 随 着 伯克利 教授 理 查 德 . 卡 
普 的 一 篇 承上启下 的 论文 而 改变 了 。 












































看 过 库 克 的 论文 以 后 ， 卡 普 意 识 到 有 一 种 方法 可 以 把 可 满足 性 归 约 到 团 问题 。 卡 
普 建 立 了 一 个 简单 的 计算 过 程 ， 它 能 把 给 定 逻 辑 表 达 式 转换 成 相应 的 好 友 关 系 图 , 并 
有 当 且 仅 当 关系 图 上 存在 等 于 某 个 数 的 团 时 ， 表 达 式 为 真 。 任 何 能 解决 团 问题 的 算法 
都 可 以 用 来 解决 满足 性 问题 。 库 克 表 明了 可 满足 性 是 NP 问题 中 最 难 的 。 而 卡 普 表 明 ， 
团 问题 至 少 和 可 满足 性 问题 一 样 难 。 这 样 一 来 , 团 问题 就 成 为 NP 最 难 的 问题 之 一 。 和 
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可 满足 性 问题 一 样 , 如 果 我 们 找到 了 团 问题 的 快速 解法 , 那么 所 有 NP 类 问题 就 迎 为 而 
解 ， 从 而 证 明 P= NP 。 


库 克 表 明了 如 何 把 类 似 团 这 样 的 问题 归 约 到 可 满足 性 问题 。 卡 普 则 表明 可 满足 
性 可 归 约 为 团 问题 。 这 两 个 表面 看 上 去 非常 不 同 的 问题 ,在 计算 角度 上 竞 然 是 相同 
的 。 可 满足 性 容易 计算 的 充分 必要 条 件 是 团 问题 容易 计算 ,而 后 者 的 充分 必要 条 件 
是 P=NP。 




















卡 普 不 仅 证 明了 团 问 题 是 NP 中 最 难 的 问题 之 一 ,而 且 找 出 了 其 他 19 个 同样 难度 的 
重要 问题 ， 包 括 分 割 难题 、 旅 行 推销 员 、 哈 密 顿 回路 、 地 图 填 色 以 及 最 大 割 。 只 要 有 
效 解决 了 这 些 问 题 中 的 任意 一 个 ， 你 就 能 解决 所 有 问题 并 证 明 P=NP 。 如 果 说 
Pz NP ， 那 么 这 21 个 问题 ( 包括 可 满足 性 问题 ) 没有 一 个 能 被 快速 地 解决 。 

















卡 普 并 不 是 凭空 创造 了 这 21 个 问题 , 对 解决 这 些 问 题 感 兴趣 的 也 不 仅 是 数学 家 和 
计算 机 科学 家 。 其 中 的 许多 问题 来 自 现实 世界 。 











比如 可 口 可 乐 公司 ， 它 旗下 的 饮料 品牌 超过 3000 个 ,行销 世界 各 地 。 一 个 可 口 可 
乐 的 灌 装 工厂 可 能 会 生产 几 百 种 不 同 的 饮料 产品 。 每 个 工厂 都 有 数 台 机 器 需要 进行 
系列 的 作业 ， 混 合 每 种 饮料 所 需 的 部 分 原料 。 这 些 机 器 可 以 生产 各 种 产品 ， 而 灌 装 工 
厂 需 要 合理 调度 机 器 的 作业 ， 以 达到 其 吞吐 量 的 最 大 值 ， 从 而 在 最 短 时 间 内 生产 出 最 
多 的 饮料 产品 。 这 是 一 个 作业 调度 问题 , 它 也 在 卡 普 列 出 的 21 个 问题 之 中 ， 其 求解 难 
度 不 亚 于 任何 其 他 的 NP 问 题 。 



























































从 电子 计算 机 诞生 之 日 起 ， 科 学 家 和 程序 员 就 在 尽 最 大 努力 ， 研 发 解决 作业 调度 
问题 的 最 佳 算 法 ， 因 为 一 个 很 小 的 调度 改进 就 可 能 为 菏 个 企业 节省 数 百 万 美元 。 还 没 
有 人 写 出 对 所 有 调度 问题 都 能 给 出 最 好 方案 的 算法 。 卡 普 证 明 ， 甚 至 连 调度 的 简单 改 
进 也 是 一 个 难度 不 亚 于 任意 NP 问题 的 难题 ,这 也 立即 揭示 了 为 什么 人 们 找 不 到 那些 调 
度 改 进 算法 。 



































不 仅 是 大 公司 会 关心 这 些 问 题 。 假 设 你 带 家 人 去 迪士尼 乐园 春游 ， 因 为 放假 所 以 
要 排 长 队 。 你 想 尽 可 能 多 玩 些 好 的 娱乐 景点 ,减少 排队 浪费 的 时 间 。《 迪 士 尼 乐 园 非 
官方 指南 》 的 作者 想 出 了 一 整套 如 何 减少 等 待 时 间 的 游玩 攻略 ,但 同时 他 们 也 承认 自 
己 在 做 一 件 很 困难 的 事 。 
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魔法 王国 景区 21 个 景点 一 日 游 ， 针 对 成 人 的 可 能 游览 方案 总 数 是 让 人 震惊 的 
51 090 942 171 709 440 000 种 。 那 可 是 超过 5100 亿 亿 种 的 组 合 ， 大 概 是 地 球 上 沙 粒 总 
数 的 6 倍 。 要 是 再 考虑 上 快速 排 号 系统 (FASTPASS )、 游 行 、 吃 饭 和 休息 等 ， 就 更 复 
杂 了 ， 组 合 的 数量 还 得 增加 好 多 。 









































类 似 的 问题 也 困扰 了 科学 家 们 很 多 年 。 比 如 , 快递 公司 会 关心 如 何 安排 每 个 送 货 
员 的 路 线 , 让 行驶 距离 最 短 ， 从 而 节省 时 间 和 燃料 。 事 实 上 ,这 类 “如 何以 最 小 的 代 
价 访问 多 个 地 点 ”的 问题 十 分 普遍 ， 人 们 给 它们 起 了 一 个 外 号 : 旅行 推销 员 问 题 。 

















许多 科学 家 尝试 过 找 出 旅行 推销 员 问 题 的 最 佳 解法 。 还 有 人 试 过 为 作业 调度 问题 
找到 一 个 高 明 的 算法 。 另 外 人 们 还 尝试 过 求解 团 、 最 大 割 以 及 其 他 卡 普 所 列 出 的 算法 。 
卡 普 的 论文 意味 着 所 有 这 些 研 究 者 研究 的 其 实 是 一 个 问题 ,因为 如 果 某 人 为 其 中 某 一 
个 算法 找 出 了 有 效 的 解法 ,那么 所 有 其 余 的 算法 就 迎刃而解 了 。 

















同 理 , 所 有 这 些 独 立 工作 的 研究 者 之 中 没有 一 个 人 能 对 他 们 所 研究 的 特定 问题 找 
到 有 效 的 解法 ,这 很 可 能 暗示 了 了 ANP, 或 者 至 少 可 以 说 , 很 难为 这 些 问题 中 的 任意 
一 个 找到 好 的 算法 。 所 以 作业 调度 的 技术 员 们 可 以 理直气壮 地 告诉 老板 ， 我 们 是 找 不 
到 机 器 上 最 好 的 作业 调度 方法 ,但 不 只 是 我 们 不 行 , 连 奥兰多 的 那 帮 机 灵 鬼 都 搞 不 定 
迪士尼 乐园 的 游览 线路 规划 呢 。 












































而 卡 善 的 工作 ， 一 下 子 就 把 所 有 这 些 出 了 名 的 难以 解决 的 计算 问题 联系 到 了 一 
起 。 从 此 ，P/NP 问 题 成 为 众人 瞩目 的 焦点 。 








每 年 计算 机 协会 都 会 颁发 ACM 图 灵 奖 ， 其 地 位 相当 于 计算 机 科学 界 的 诺 贝尔 奖 。 
该 奖 得 名 于 数学 家 阿兰 - 图 录 , 他 在 20 世 纪 30 年 代为 计算 机 科学 奠定 了 基础 。 ACM 将 
1982 年 的 图 灵 奖 授予 斯 蒂 芬 . 库 克 ， 以 表彰 他 为 P/NP 问 题 的 建立 所 做 出 的 杰出 贡献 。 
但 一 个 图 灵 奖 还 不 够 ， 理 查 德 . 卡 普 于 1985 年 也 获得 了 图 灵 奖 ， 奖 励 他 在 算法 理论 方 
面 的 杰出 工作 ， 特 别 是 列 出 了 21 个 NP 完 全 问题 。 









































43 起 个 好 名 字 有 那么 重要 吗 

















卡 普 的 论文 给 出 了 我 们 今天 使 用 的 P 和 NP 这 些 名 字 。 但 是 该 怎么 称呼 那些 NP 中 最 
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难 的 问题 呢 ? 库 克 用 了 一 个 非常 学 术 的 名 称 aeg({DNE à 
( 多项式 时 间 ) 完全 。 可 是 这 些 名 字 太 别扭 了 。 


言 式 }) ， 而 卡 普 使 用 了 术语 





na 








高 德 纳 接手 了 这 个 命名 问题 。 鉴 于 他 一 贯 杰 出 的 研究 工作 以 及 宛如 丰碑 般 的 三 卷 
巨著 《计算 机 程序 设计 艺术 》"， 高 德 纳 在 1974 年 获得 图 灵 奖 。 由 于 认识 到 了 P/NP 问 
题 至 关 重 要 的 作用 ,高 德 纳 想 在 第 4 卷 中 最 终 斋 定 这 个 NP 中 最 难 问题 集合 的 命名 。1973 
年 ， 他 通过 普通 邮件 做 了 一 次 投票 调查 。 他 直到 今天 都 坚持 不 用 电子 邮件 ， 这 在 业界 
是 很 有 名 的 。 但 在 1973 年 ， 只 有 普通 邮件 可 用 。 









































高 德 纳 在 投票 中 给 出 的 几 个 候选 项 一 一 herculean (艰巨 )、formidable (可怕) 
和 arduous( 费劲 )， 都 不 怎么 受 欢迎 。 他 收 到 了 许多 来 信和 建议 ， 有 些 很 直 白 ， 如 
intractable ( 顽固 ) 和 obstinate ( £45 ), 有 些 则 更 加 口语 化 ， 如 hard-boiled ( 原意 是 
孝 得 很 硬 的 蛋 ， 可 能 是 在 向 库 克 致敬 >) fühard-ass ( 抗 接 的 混蛋 ,简直 像 可 满足 性 
[Ry — FEES )。 
































最 终 获 胜 的 来 信 建 议 是 “NP-complete”(NP 完 全 )， 它 由 新 泽 西 州 贝尔 实验 室 的 
几 个 人 提出 ， 是 那里 的 研究 者 经 过 多 次 讨论 之 后 产生 的 。“complete”( 完全 或 完备 ) 
这 个 词 出 自 数学 逻辑 学 ,一 个 事实 集合 被 称 为 完备 的 ， 就 是 说 它 能 解释 某 些 逻辑 系统 
的 所 有 真 命题 。 类 似 地 ,， “NP 完全 ”表示 这 些 NP 问 题 的 集合 强大 到 能 够 用 来 解决 任何 
其 他 的 NP 问题 。 



































高 德 纳 对 这 个 民选 结果 不 太 满 意 ,但 也 没有 觉得 它 差 到 让 人 活 不 下 去 的 地 步 。 他 
本 人 特别 想 要 找 一 个 英文 词 ， 既 能 捕捉 “困难 的 搜索 问题 ”这 个 直观 的 意象 ， 又 要 琅 
琅 上 口 ， 便 于 向 大 众 普 及 。1974 年 ， 高 德 纳 总 结 了 他 的 调查 过 程 ， 文 中 写 道 :““NP 完 
AU 这 个 名 字 其 实学 术 气 息 有 点 儿 浓 , 不 好 向 大 众 推 广 , 但 也 没有 差 到 不 能 用 的 地 步 。” 





























“NP 完 全 ”很 快 成 为 标准 术语 。 高 德 纳 用 了 大 概 40 年 才 完成 巨著 的 第 4 卷 。 











其 实 高 德 纳 当 年 本 应 该 坚持 已 见 ， 为 “NP 完 全 ”， 甚 至 “P” 和 “NP” 这 些 概念 敲 
定 一 些 不 那么 学 术 的 术语 。 P/NP 问 题 的 重要 性 已 经 远 远 超出 了 计算 机 科学 领域 , 而 这 种 





























QD《 计 算 机 程序 设计 艺术 》 卷 1 、 卷 2>、 卷 3 、 卷 4A 的 英文 版 均 已 由 人 民 邮 电 出 版 社 出 版 ， 中 文 版 也 会 
相继 呈现 给 读者 ， 详 情 请 登录 图 灵 社 区 ( www.ituring.com.cn ) 查阅 相关 图 书 。 一 一 编者 注 
@) 库 克 (Cook) 这 个 姓 的 原意 为 “厨师 "。 一 一 译 者 注 
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将 术语 的 首 字母 缩写 的 命名 方式 , 阻碍 了 门外汉 对 其 重要 性 的 认 知 。 但 这 些 术语 在 几 十 
年 后 已 经 在 文化 中 根深 蒂 固 ， 即 使 现在 我 们 想到 了 更 好 的 名 字 ， 疏 伯 也 不 好 纠正 了 。 























高 德 纳 也 意识 到 ,如果 最 终 证 明 P= NP , 也 就 是 说 NP 完全 问题 其 实 就 是 P 中 的 问 
题 ， 那 么 之 前 为 它 起 名 字 而 做 出 的 种 种 努力 岂 不 全 都 白费 了 。 但 是 高 德 纳 说 了 :“ 即 
使 将 来 可 能 觉得 尴 询 ,我 也 愿意 冒 这 个 险 一 一 我 将 奖 给 第 一 个 证 明 P= NP 的 人 一 只 活 
踢 乱 跳 的 火 鸡 。” 所 以 现在 证 明 P= NP 的 人 可 以 赢得 100 万 美元 ， 外 加 一 只 火 鸡 。 























44 超越 卡 普 的 工作 





在 卡 普 的 论文 之 后 , 计算 机 科学 界 掀起 了 一 个 寻找 并 证 明 各 种 问题 是 否 属于 NP 
完全 的 热潮 。 在 接 下 来 的 几 年 里 ,教授 和 研究 生 们 成 功 证 明了 许多 已 知 的 搜索 问题 
(以 及 一 些 新 间 题 ) 是 NP 完 全 的 。 一 本 1979 年 出 版 的 书 " 中 列举 了 三 百 多 个 主要 的 N 
完全 问题 。NP 完 全 问题 持续 在 各 个 领域 涌现 ， 如 计算 机 科学 、 物 理学 、 生 物 学 、 经 





e 





济 学 , 以 及 其 他 许多 攀登 到 困难 顶峰 的 学 科 。Google 学 术 搜索 NP-Complete 将 返回 超 
过 138 000 篇 科研 文献 ， 时 间 跨 度 从 1972 年 到 2011 年 ， 单 是 2011 年 就 有 近 1 万 篇 。 我 
们 在 此 无 法 一 一 列举 ， 只 从 中 挑选 几 篇 ， 看 看 这 些 文章 是 什么 风格 。 








1. 支配 集 (Dominating Set) 

















敌 友 国 是 否 存 在 这 样 的 50 个 人 : 其 余 的 人 和 这 50 个 人 中 的 至 少 1 个 是 朋友 ?NP 完 
全 问题 。 





2. 三 角 切 分 问题 (Partition into Triangles) 





敌 友 国 理工 学 院 的 每 个 宿舍 只 能 容纳 三 名 学 生 。 我 们 能 把 所 有 敌人 都 安排 在 不 同 
的 宿舍 里 吗 ? NP 完 全 问题 。 








3. 大 规模 数 独 游戏 





数 独 ( Sudoku ) 是 一 种 起 源 于 日 本 的 填 数 字 游 戏 ， 使 用 一 个 9 x 9 的 格子 ， 如 下 图 
所 示 。 








(D Computers and Intractability: A Guide to the Theory of NP-Completeness, 作者 Michael Garey 和 David 
Johnson ( New York: W. H. Freeman, 1979 )。 
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图 4-2 Wo 
数 独 的 游戏 目标 是 填 满 所 有 空格 ,并 使 每 一 行 、 每 一 列 和 由 黑 线 标 出 的 3 x 3 小 方 














格 中 的 数字 分 别 是 1 到 9 的 不 重复 的 数字 。 
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数 独 是 NP 问题 ,因为 很 好 检查 一 个 解 。 找 到 一 个 解 有 多 难 ?不 太 困 难 。 使 用 f 
的 回溯 算法 ， 普 通 计算 机 可 以 在 几 秒 内 找到 一 个 有 效 解 。 
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但 是 如 果 谜 题 的 规模 变 得 更 大 ， 像 上 面 这 个 25 x 25 的 版 本 ， 要 求 每 行 、 每 列 和 小 
方块 中 填 和 人 A 到 Y 且 不 重复 的 字母 ， 会 发 生 什 么 呢 ? 





fie 





这 回 普通 计算 机 就 得 算 好 长 时 间 了 ， 而 100 x 100 的 数 独 游戏 能 打败 当今 最 快 的 























大 规模 的 数 独 游戏 是 NP 完全 问题 ,你 自 认 为 是 数 独 高 手 ? 如果 你 能 可 靠 地 解决 大 
规模 的 数 独 ， 那 么 你 也 能 解决 可 满足 性 问题 、 旅 行 推销 员 问 题 ， 还 有 其 他 几 千 个 NP 


完全 问题 。 
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4 大 规模 的 数 独 
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图 





o 来 看 微软 Windows 系 统 自 带 的 扫雷 
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问 





个 NP 完 全 

















数 独 可 不 是 桌面 游戏 中 唯 


游戏 。 


i 
$ 
i 





E 


i Aan i" 
caes 








图 4-5 
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每 个 小 方块 埋 着 一 个 数字 或 者 地 雷 ， 数 字 代表 临近 的 方块 (包括 水 平 、 垂 直 和 对 
角 线 相 邻 ) 总 共有 几 个 地 雷 。 在 某 个 不 是 地 雷 的 方块 上 点 一 下 会 显示 出 下 面 的 数字 。 
如 果 你 觉得 方块 下 面 有 地 雷 ， 就 标 一 个 小 着 子 。 点 中 地 雷 你 就 输 了 。 判 断 能 否 玩 说 一 
个 大 规模 的 扫雷 游戏 也 是 NP 完全 问题 。 这 是 上 面 那 张 图 里 剩 下 的 地 雷 。 









































MineSweeper - Google Chro... - 


S) www.chezpoor.com/minesweeger/minecare. ntm 
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图 4-7 俄罗斯 方块 























当然 还 有 俄罗斯 方块 。 玩 家 平移 和 旋转 各 种 下 沙 的 积木 ， 填 满 一 行 的 那 一 刻 整 行 
会 消失 ， 游 戏 目标 是 不 让 整个 画面 都 被 方块 填 满 ， 坚 持 尽 可 能 长 的 时 间 。 
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积木 分 很 多 种 形状 。 
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图 4-8 ”俄罗斯 方块 的 积木 

















经 典 俄罗斯 方块 游戏 中 你 不 知道 下 一 块 积木 的 形状 。 但 即使 你 提前 知道 了 各 种 形 
状 的 积木 到 来 的 次 序 ， 如 何 把 俄罗斯 方块 玩 到 最 好 也 是 一 个 NP 完全 问题 。 

















谁 曾 想 把 数 独 、 扫 雷 和 俄罗斯 方块 这 些 游戏 玩 好 , 就 可 以 证 明 P= NP 从 而 解决 我 


们 这 一 代 面 临 的 最 大 的 挑战 呢 ? 





图 4-9 魔方 。 图 片 作 者 为 Tom van der Zanden 








魔方 又 怎么 样 呢 ? 即使 是 3 x 3x 3 的 小 魔方 一般人 也 得 花 不 少 工夫 才能 知道 如 


何 复原 ， 而 求解 更 大 的 魔方 的 难度 可 想 而 知 。 
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其 实 不 算 太 难 。 我 们 对 于 解决 更 大 规模 的 魔方 复原 问题 有 一 些 很 快 的 算法 ,它们 
都 基于 一 个 叫做 群 论 的 数学 分 支 。 这 些 算法 不 能 保证 找到 全 局 最 少 步 又 的 解法 , 但 是 
总 能 找到 足够 短 的 方法 ， 从 任何 可 能 的 打 乱 方式 开始 将 魔方 复原 。 



































与 玩 好 俄罗斯 方块 、 扫 雷 和 数 独 的 困难 程度 相 比 ， 复 原 魔方 的 问题 容易 得 出 奇 。 




















而 双人 对 战 游戏 ， 如 国际 象棋 、 跳 横 、 黑 白 棋 和 围棋 ， 它 们 的 难度 又 如 何 呢 ?这 
些 游戏 的 大 规模 版 本 , 其 难度 和 可 满足 性 问题 等 NP 完全 问题 的 难度 是 相当 的 。 但 是 
些 双人 游戏 不 属于 NP 类 问题 。 比 如 我 告诉 你 , 这 盘 国际 象棋 肯定 是 白 方 赢 ,最 后 一 
是 三 列 众 吃 王 , 你 根本 没 法 验证 我 的 话 。 计算 机 科学 家 基本 上 都 认为 国际 象棋 、 跳 棋 、 
黑 日 棋 和 围棋 的 难度 均 大 于 任何 NP 问题 。 
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4. 肾脏 交换 





正常 人 有 两 个 健康 的 肾 来 将 体内 的 代谢 废物 滤 出 体外 。 如 果 只 剩 一 个 凤 ， 人 还 是 
可 以 过 正常 的 生活 。 如 果 两 个 肾 都 不 能 用 ， 就 必须 用 透析 来 维持 生命 ， 这 不 仅 需要 耗 
费 大 量 金钱 和 时 间 ， 而 且 时 刻 都 有 可 能 死亡 。 








有 两 个 健康 肾 的 人 可 以 捐献 出 其 中 一 个 ,挽救 双 肾 衰竭 的 病人 ， 前 提 是 捐献 者 的 
肾 和 受 捐 者 的 身体 相 容 。 通 过 简单 的 抽 血 就 可 进行 这 种 相 容 性 测试 。 








假如 Alice 不 幸 双 肾 豪 竭 ， 她 的 丈夫 Bob 同 意 捐献 自己 的 一 个 月 。 如 果 Bob 的 肾 和 
Alice 的 身体 相 容 ， 那 么 可 以 通过 手术 将 Bob 的 一 个 肾 摘除 并 移植 给 Alice。 




















但 Bob 的 肾 有 可 能 受到 排斥 。 还 有 一 线 希 望 ， 就 是 所 谓 肾脏 交换 项 目 。 


假如 男 一 个 人 Charlie 也 需要 肾 ， 愿 意 为 他 捐 肾 的 是 他 兄弟 David， 而 David 的 肾 也 
和 Charlie 不 相 容 。 然而 , 如 果 David 的 肾 与 Alice 相 容 , 并 且 Bob 的 肾 和 Charlie 的 肾 相 容 ， 
那么 就 可 以 安排 让 四 人 同时 上 手术 台 , 这 样 术 后 每 个 人 都 有 一 个 好 肾 , 挽救 两 条 生命 。 











假设 我 们 有 了 关于 上 述 这 样 潜在 的 肾脏 捐献 者 -接受 者 的 数据 库 ， 就 可 通过 有 效 
的 算法 ， 证 尽 可 能 多 的 两 对 捐献 者 -接受 者 成 功 配对 ， 达 成 骨 脏 交换 。 基 本 上 这 就 是 
前 一 章 介 绍 过 的 配对 问题 ， 很 容易 解决 。 


























不 止 是 两 个 人 ,， 还 可 以 有 更 多 人 来 配对 。2011 年 年 末 ，60 场 手术 为 30 位 患者 移植 

















了 健康 的 肾脏 ， 这 是 通过 其 他 任何 方法 都 不 可 能 做 到 的 。 
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然而 如 果 允 许多 于 两 对 的 捐献 者 -接受 者 互 换 肾脏 ,如何 找 到 尽 可 能 多 的 多 人 搭 





配方 案 在 目前 还 是 一 个 NP 完全 问题 。P = NP BU 


玩 好 扫雷 重要 得 多 。 


45 WAZE 


人 们 在 20 世 纪 70 年 代 所 研究 的 大 前 








E 明 在 这 里 是 性 命 侯 关 的 ， 可 比如 何 





分 NP 问题 ， 都 要 么 被 认定 





属于 NP 完全 问题 ， 


要 么 被 有 效 解决 ， 从 而 归属 于 P。 但 还 是 有 一 些 NP 问 题 竖 痪 不 灵 ， 难 以 确定 其 归属 。 
这 些 问 题 中 的 一 部 分 在 很 多 年 后 被 解决 了 ， 另 一 部 分 直到 今天 都 还 没有 被 定性 ， 成 为 


漏网 之 鱼 。 





1. 图 的 同 构 问 题 


在 敌 友 国 流行 着 一 个 叫 “ 刀 剑 生 


























F 程 ”( Blade Quest ) 的 MMORPG ( 大 型 多 人 在 线 





角色 扮演 游戏 ) 游戏 中 每 个 玩家 都 会 起 一 个 新 名 字 ， 操 纵 一 个 虚拟 角色 (avatar) 去 
和 其 他 玩家 的 虚拟 角色 进行 互动 。 敌 友 国 的 敌 友 关系 也 被 引入 了 刀剑 征程 的 世界 。 在 
现实 中 互 为 朋友 的 居民 ， 他 们 在 游戏 中 的 虚拟 角色 也 是 朋友 关系 ; 相反 ， 现 实 中 的 政 





人 在 游戏 里 也 是 敌人 。 

















Isabel、John、Kevin、Laura、Molly 和 Nancy 是 几 个 喜欢 玩 刀 剑 征程 的 敌 友 国 居 民 。 


Isabel 


John Kevin 


小 


Laura Nancy 


/ 
N 


Molly 


图 4-10” 玩 刀剑 征程 的 居民 
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这 6 个 人 在 游戏 中 的 虚拟 角色 的 名 字 是 Achris 、Bolem 、Chyrard、Degarald、Enthrr 
和 Fev， 但 是 哪个 虚拟 角色 对 应 哪个 真人 是 保密 的 。 在 刀剑 征程 中 ， 这 几 个 虚拟 角色 
也 有 一 个 好 友 关 系 图 。 
































Achris 
Bolem Degarald 
Chryard pa Enthrr 
Fev 








图 4-11 “刀剑 征程 中 的 虚拟 角色 











Laura 看 了 这 两 张 图 ， 就 在 游戏 里 给 别 的 玩家 发 了 一 个 消息 :“ 我 知道 你 在 现实 中 
是 谁 。 ”你 能 猜 出 来 吗 ? 








这 两 张 图 存在 唯一 的 对 应 方式 , 即 Isabelle 在 游戏 中 对 应 的 虚拟 角色 是 Enthrr, John 
是 Degarald，Kevin 是 Chryard，Laura 是 Bolem，Molly 是 Achris， 还 有 Nancy 是 Fev。 我 
们 可 以 验证 一 下 ， 如 Molly 在 敌 友 国 的 朋友 是 Laura 和 Nancy， 与 之 对 应 ， 在 刀剑 征程 
中 Achris 的 朋友 是 Bolem 和 Fev。 






































好 友 关 系 图 之 间 的 映射 被 称 为 图 的 同 构 问 题 。 有 可 能 存在 多 种 映射 ， 也 可 能 不 存 
TE, 这 取决 于 给 定 的 图 集 。 图 的 同 构 性 属于 NP 类 问题 如 果 知 道 了 谁 对 应 谁 ， 你 可 以 
通过 逐 对 查看 好 友 关 系 在 两 张 图 中 是 否 一 致 来 验证 这 个 解 的 有 效 性 。 


















































但 是 图 同 构 是 否 属于 P， 即 我 们 是 否 能 找到 图 之 间 的 映射 (假设 存在 ) 的 有 效 算 
ik. 还 是 未 知 的 。 我 们 也 不 确定 图 同 构 是 NP 完全 的 ,而 出 于 多 种 技术 原因 ,计算 机 科 
学 家 也 不 认为 它 是 NP 完 全 的 。 岁 同 构 属于 另 一 小 报 问 题 ， 其 难度 比 P 问 题 大 ， 但 比 不 
上 哈密 顿 回 路 、 最 大 割 等 NP 完 全 问题 。 



































2. 质数 和 因数 分 解 


你 可 以 对 15 进 行 因数 分 解 ， 得 出 15 x 1 或 5 x 3。24 这 个 数 可 等 于 24x1、12x2、 
8 x 3 或 6x4。 但 是 你 只 能 把 17 写 作 17 x 1。17 是 一 个 质数 ， 即 只 能 把 它 写 作 1 和 自身 乘 
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积 的 数 。 最 开始 的 几 个 质数 是 >-、3、5、7、11、13、17、19。 质 数 有 无 限 多 个 。 EUR 
的 最 大 质数 ( 在 我 写作 之 时 ) 是 一 个 12 978 189 位 的 数 , 它 开始 的 几 位 是 316 470 269 330 
255 923 143 453 723- 
































怎么 判断 一 个 数 是 否 是 质数 ? 例如 要 判断 1 123 467 619 是 否 是 质数 ， 你 需要 遍历 
所 有 小 于 1 123 467 619 的 数 , 看 看 是 否 有 能 整除 它 的 数 。 事 实 上 你 只 需要 检查 到 33 518 
(1123 467 619 的 平方 根 ) 就 可 以 了 。 听 起 来 是 挺 快 ,可 是 你 如 何 判 断 下 面 这 个 数 是 否 
为 质数 ? 


— 












































8 273 820 869 309 776 799 973 961 823 304 474 636 656 020 157 784 206 028 082 108 
433 763 964 611 304 313 040 029 095 633 352 319 623 


早 在 古 希 腊 就 出 现 了 判定 质数 的 算法 , 但 直到 20 世 纪 70 年 代 才 出 现 对 几 百 位 数 有 
效 的 算法 。 这 些 算法 基于 数学 中 一 个 叫 数论 的 领域 的 研究 成 果 ， 在 检查 时 需要 使 用 随 
机 生成 的 数 。 昌 然 这 些 算法 在 实践 中 表现 很 好 ,但 是 不 依赖 于 随机 生成 数 的 质数 判定 
算法 直到 2002 年 ， 才 由 一 位 印度 教授 曼 尼 达 ' 阿 加 拉 瓦 尔 带领 他 的 学 生 尼 拉 吉 “' 卡 
亚 尔 和 尼 洒 ， 萨克斯 纳 发 现 ， 从 而 把 该 问题 归属 于 P 类 问题 。 


这 些 算 法 虽然 能 告诉 我 们 



































8273 820 869 309 776 799 973 961 823 304 474 636 656 020 157 784 206 028 082 108 
433 763 964 611 304 313 040 029 095 633 352 319 623 


这 个 数 不 是 质数 , 但 令 人 惊奇 的 是 ， 它 们 不 能 告诉 你 这 个 数 的 因子 有 哪些 ， 也 就 是 说 
不 能 对 其 因数 分 解 。 


我 们 有 判定 质数 的 有 效 算 法 ， 但 是 没有 分 解 因数 的 有 效 算法 。 
因数 分 解 是 一 个 NP 问 题 ， 因 为 如 果 你 看 到 了 








84 578 657 802 148 566 360 817 045 728 307 604 764 590 139 606 051 
和 
97 823 979 291 139 750 018 446 800 724 120 182 692 777 022 032 973 


这 两 个 数 ， 把 它们 相 乘 就 可 验证 乘积 等 于 上 面 的 
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8 273 820 869 309 776 799 973 961 823 304 474 636 656 020 157 784 206 028 082 108 
433 763 964 611 304 313 040 029 095 633 352 319 623 























计算 机 科学 家 认为 因数 分 解 不 属于 P 类 问题 ， 也 觉得 它 不 是 NP 完全 问题 。 它 是 很 
难 ， 但 不 像 可 满足 性 问题 或 地 图 填 色 问题 那样 难 。 








不 只 是 喜欢 摆弄 数字 的 数学 家 们 认为 质数 判定 和 因数 分 解 问题 很 重要 。 现 代 密码 
学 的 许多 方法 都 依赖 于 某 些 难以 分 解 因数 的 大 数 ， 这 是 第 8 章 的 话题 。 














3. 线性 规划 





敌 友 国有 一 个 熟食 店 叫 Frenemy Fancy Franks, 里 面 出 售 四 种 口味 的 香肠 : 法 兰 克 福 
香肠 、 意 大 利 香肠 、 德 国 香 肠 和 西班牙 香肠 。 不 同 种 类 的 香肠 制作 时 间 不 同 , 售 价 也 有 
差别 。Frenemy Fancy Franks 应 该 如 何 安 排 每 种 香肠 制作 的 数量 , 以 获取 最 大 的 利润 呢 ? 




















找到 最 优 的 方案 就 是 在 满足 各 种 限制 条 件 的 前 提 下 使 收入 最 大 化 。 假设 制作 一 根 
法 兰 克 福 香 肠 的 成 本 是 1 美元 ， 意 大 利 香肠 的 成 本 是 2 美元 ， 德 国 香肠 是 3 美元 ， 西 班 
牙 香肠 是 4 美元 ， 且 每 日 的 总 预算 是 1 万 美元 。 那 么 ，1 乘 以 法 兰 克 福 香肠 的 数量 ， 加 
上 2 乘 以 意大利 香肠 的 数量 ， 加 上 3 乘 以 德国 香肠 的 数量 ， 加 上 4 乘 以 西班牙 香肠 的 数 
量 ， 结 果 应 不 超过 1 万 。 



























































在 这 类 条 件 下 进行 最 优化 选择 的 问题 叫做 线性 规划 。 可 能 的 解 集 在 高 维 空间 形成 
一 个 几何 体 ， 叫 做 多 面体 。 


早 在 1947 年 ， 格 奥 尔 格 ， 丹 齐 克 发 明了 单纯 形 法 (simplex method )， 这 种 方法 能 
很 快 解决 线性 规划 问题 。 单 纯 形 法 遍历 多 面体 所 有 的 边 ， 直 到 找 出 最 佳 的 解 集 。 








既然 有 了 单纯 形 法 ,我 为 什么 要 把 线性 规划 放 在 〈20 世 纪 70 年 代 ) 未 分 类 的 问题 
里 面 呢 ? 因为 在 某 些 罕见 的 个 例 中 ,单纯 形 法 无 法 快速 求解 线性 规划 问题 。 




















1979 年 ， 利 奥 尼 德 . 卡 奇 安 发 明了 椭 球 算法 (ellipsoid algorithm )， 基 本 思路 是 把 
多 面体 切 分 成 越 来 越 小 的 块 ， 不断 缩小 范围 并 最 终 找 到 最 优 解 。 卡 奇 安 给 出 了 椭 球 算 
法 有 效 性 的 证 明 ， 从 而 把 线性 规划 分 到 了 P 类 问题 中 。 然 而 实践 中 椭 球 算法 的 耗 时 比 
单纯 形 法 要 长 很 多 。 HASCE SOME, 但 椭 球 算法 在 之 后 的 几 十 年 中 启发 了 许多 更 复 
杂 的 算法 的 诞生 ， 因 而 它 在 学 术 上 还 是 很 有 影响 力 的 。 
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图 4-12 ”多 面体 





这 样 一 来 , 线性 规划 在 理论 和 实践 上 分 别 都 有 了 好 的 解决 算法 一 一 只 不 过 是 两 种 
非常 不 同 的 算法 。 





1984 年 ， 纳 伦 德 拉 “' 卡 马 卡 发 明了 内 点 算法 (interior point algorithm )。 和 单纯 形 
法 类 似 ， 卡 马 卡 的 算法 遍历 多 面体 ， 只 不 过 是 在 内 部 遍历 而 不 是 表面 。 和 椭 球 算法 一 
样 ， 内 点 算法 也 能 将 线性 规划 归属 到 PP 类， 并且 在 经 过 优化 后 该 算法 的 实际 性 能 甚至 
高 于 单纯 形 法 。 



































以 上 就 是 解决 线性 规划 问题 的 三 种 非常 不 同 的 算法 。 第 一 种 (单纯 形 ) 在 实践 上 
表现 很 好 。 第 二 种 OMER) 在 理论 上 很 好 。 而 第 三 种 ( 内 点 ) 则 在 理论 和 实践 上 的 表 
现 都 很 好 。 能 对 一 个 在 20 世 纪 70 年 代 末 还 被 认为 是 未 解决 的 问题 给 出 这 三 份 答 案 , 是 
很 值得 人 们 为 之 自豪 的 进步 。 











SC. Dm L 
P 和 NP 诞生 前 的 历史 














不 要 怕 蛮 力 搜 索 ， 而 是 要 合理 使 用 它 。™ 














在 上 一 章 中 我 们 讲 到 了 高 德 纳 最 终 没 能 为 NP 完全 问题 找到 一 个 更 恰当 的 英语 单 
Wo 如 果 他 当初 把 眼光 投向 东方 的 俄罗斯 , 就 会 发 现 一 个 合适 的 词 perebor ( IIepe6op ), 
意 为 “使 用 蛮 力 来 搜索 "， 即 尝试 所 有 可 能 性 以 找到 最 佳 方案 。P/NP 问 题 其 实 是 在 问 ， 
我 们 是 否 必 须 用 蛋 力 搜索 来 解决 团 问 题 ， 还 是 存在 更 快 的 方法 也 能 达到 目的 。 


















































但 是 当年 高 德 纳 和 其 他 美国 人 一 样 ， 都 很 难 了 解 俄罗斯 发 生 的 事情 。 从 1945 
年 第 二 次 世界 大 战 结束 起 , 一道 铁 幕 将 当时 的 苏联 与 东欧 ， 以 及 美国 与 西欧 隔绝 开 
来 。 从 20 世 纪 50 年 代 开 始 , 冷战 导致 美国 和 苏联 两 国 围绕 着 科 拉 发展 展开 了 一 系列 
竞争 ， 两 国都 想 说 得 这 场 知 识 领域 的 “军备 竞赛 "。 由 此 带 来 的 一 个 负面 影响 是 基 
本 断绝 了 东西 方 科学 界 的 互 访 和 交流 。 尺 管 情况 在 20 世 纪 70 年 代 有 所 缓和 , 但 直到 
1991 年 冷战 结束 ,东西 方才 恢复 了 全 面 的 科研 交流 和 讨论 。 如 今 ， 随 着 大 部 分 的 学 
术 成 果 都 被 放 到 网 上 供 人 查阅 , 再 加 上 学 者 可 以 较为 自由 地 到 世界 各 地 进行 学 术 访 
Ij, 我 们 可 以 认为 全 球 同属 一 个 学 术 研 究 社 群 ， 而 不 是 被 人 为 地 分 成 两 个 互 不 来 往 
的 社 群 。 































































































这 一 章 讲述 了 两 个 故事 ,两 条 通 往 P/INP 问 题 的 道路 。 结 局 是 西方 的 斯 蒂 芬 ， 库 克 
和 东方 的 列 昂 尼 德 ' 莱 文 分 别 率先 提出 了 是 否 P= NP 的 问题 。 但 是 科学 并 不 是 凭空 发 
生 的 , 两 边 的 科研 都 经 过 了 漫长 的 路 程 , 最 终 才 可 能 产生 库 元 和 莱 文 的 工作 。 在 本 章 ， 
我 们 会 截取 这 两 段 历史 的 几 个 片段 进行 讲述 , 包括 西方 对 于 高 效能 计算 的 本 质 的 苦 若 
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探索 ， 以 及 东方 对 蛮 力 搜索 的 必要 性 的 理解 。 最 终 我 们 会 发 现 二 者 殊途同归 ,， 走 到 了 
P/NP 问 题 面前 。 








51 西方 








对 高 效能 算法 的 探索 可 追溯 到 大 约 3000 年 前 ， 人 类 第 一 次 使 用 基本 算术 来 做 大 数 
的 加 法 。 而 我 们 的 故事 从 20 世 纪 30 年 代 开 始 ， 当 时 人 们 开始 建立 算法 过 程 的 理论 。 











1. 阿兰 图 灵 


我 们 为 探索 太空 而 发 明了 望远镜 ,借助 它 我 们 能 看 到 宇宙 遥远 的 地 方 ， 了 解 它 早 
期 的 历史 。 我 们 建造 了 能 看 到 原子 的 显微镜 ,也 建造 了 巨大 的 机 器用 以 击 碎 微小 的 粒 
子 从 而 找到 更 小 的 粒子 。 我们 甚至 破译 了 人 类 的 DNA。 但 是 有 一 样 事物 ， 它 出 现在 我 
们 的 桌 上 、 车 内 ， 甚 至 口袋 里 ， 但 我 们 仍然 觉得 它 很 神秘 ， 这 就 是 计算 机 。 计 算 机 到 
底 是 什么 ? 
































computer ( 计算 机 ) 这 个 词 早 在 17 世 纪 就 出 现 了 ， 那 时 还 没有 人 想象 过 机 器 可 以 
做 数学 运算 。 那 时 的 computer 是 计算 员 ， 即 做 计算 工作 的 人 。 刚 刚 兴 起 的 银行 业 需 要 
计算 员 来 记录 和 追踪 每 一 笔 存款 和 借贷 的 账目 。 

















根据 《牛津 英语 字典 》 第 一 次 将 computer 用 于 指 代 能 计算 的 设备 是 在 1897 年 ， 而 
电子 计算 机 投入 使 用 是 在 20 世 纪 40 年 代 。computer 的 意义 ， 从 一 种 人 变 为 几 台 庞大 的 
机 器 ， 又 变 成 了 人 们 的 日 用 品 。 











不 要 把 计算 机 看 成 是 机 器 ， 想 想 它 的 功能 : 接收 信息 ,根据 指令 处 理 信息 ， 然 后 
产生 输出 。 从 功能 角度 讲 ， 邮 政 服务 是 一 台 计 算 机 : 接收 信件 ， 解 码 地 址 ， 然 后 把 信 
件 分 发 投递 到 合适 的 位 置 。 生 物 学 过 程 也 是 一 台 计 算 机 : 接收 DNA 序 列 , 产 出 维持 生 
命 所 需 各 种 功能 的 蛋白 质 。 


















































而 我 们 称 之 为 计算 的 过 程 又 是 什么 呢 ? 有 没有 不 能 被 计算 的 事物 ? 这 个 谜 题 在 
电子 计算 机 问世 之 前 的 1936 年 ， 就 被 伟大 的 数学 家 阿兰 ， 图 灵 解 开 了 。 图 灵 研 究 了 数 
学 家 的 思考 方式 ， 并 模拟 这 种 思维 过 程 发 明了 一 个 形式 化 的 数学 模型 ， 我 们 现在 称 之 
为 图 灵机 ， 已 成 为 计算 学 的 标准 模型 。 
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阿兰 . 图 灵 1912 年 生 于 伦敦 。20 世 纪 30 年 代 初 ， 他 考 入 剑桥 大 学 国王 学 院 ， 展 露 
出 过 人 的 数学 才华 。 那 段 时 间 里 ,他 从 一 个 数学 家 的 角度 ， 思 考 了 计算 的 本 质 。 数 学 
家 在 思考 时 有 一 定 的 方法 步 又 ,尽管 人 的 记忆 容量 非常 有 限 ， 但 是 记录 信息 的 纸 和 笔 
则 可 以 敞开 供应 。 数 学 家 会 在 一 页 纸 上 缴 匆 写 下 一 些 笔记 ， 写 完 一 张 纸 后 要 么 再 用 一 
张 纸 ， 要 么 回 到 之 前 写 过 的 某 张 纸 ， 对 笔记 进行 一 些 修改 。 图 灵 受 这 个 过 程 的 启发 ， 
创造 了 一 个 形式 化 的 计算 模型 ， 即 我 们 所 熟悉 的 图 灵机 。 
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图 5-1 图 灵机 








尽管 结构 非常 简单 ， 但 图 灵 宣 称 ， 他 的 机 器 模型 可 计算 一 切 能 被 计算 的 事物 。 几 
乎 在 同一 时 间 ， 阿 隆 佐 ' 丘 奇 也 宣称 它 的 Lambda Calculus (和 演算 ， 一 种 原始 的 编程 
语言 ) 能 做 同样 的 事情 。 丘 奇 - 图 灵 论 题 虽然 在 现代 计算 机 发 明之 前 就 已 产生 ,但 它 
通过 了 时 间 的 考验 。 图 灵机 能 计算 现 有 或 将 来 一 切 能 被 计算 的 事物 。 任 何其 他 计算 机 
器 模型 的 能 力 都 不 会 超出 图 灵机 。 














你 不 一 定 非 要 理解 图 灵机 的 工作 原理 才能 理解 计算 。 只 需要 想 想 任意 一 种 编程 语 
言 , 假设 可 利用 的 存储 空间 是 无 限 的 。 所 有 编程 语言 在 功能 上 是 等 效 的 ， 并 且 其 计算 
能 力 都 等 于 简单 的 图 灵机 的 计算 能 力 。 






































图 灵 在 1936 年 就 指出 ， 图 灵机 并 不 是 什么 都 能 计算 。 最 著名 的 例子 是 停机 问题 ， 
即 没 有 计算 机 能 通过 查看 一 段 代码 就 知道 自己 是 会 永远 执行 下 去 还 是 会 最 终 停止 。 




















在 第 二 次 世界 大 战 期 间 , 图 灵 在 英国 的 密码 破译 工作 中 承担 了 重要 的 任务 。 战 后 ， 
他 开始 考虑 图 灵机 是 否 是 以 人 脑 为 原型 的 。 他 引入 了 今天 我 们 称 之 为 “图 灵 测 试 ”的 
判定 方法 ,判定 机 带 是 否 可 以 表现 出 类 人 的 智能 。 假设 你 通过 即时 通信 软件 和 别人 聊 
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K, 你 能 判断 和 你 聊天 的 是 真人 还 是 计算 机 程序 吗 ?如 果 一 个 计算 机 能 让 大 部 分 人 误 
以 为 它 是 真人 ， 它 就 通过 了 图 灵 测 试 。 























不 幸 的 是 图 灵 的 学 术 生 涯 半路 天 折 。 他 于 1952 年 因 同 性 恋 行为 被 当时 的 英国 司法 
机 关 判 定 有 罪 ， 这 最 终 导 致 了 他 在 1954 年 自杀 。 直 到 2009 年 ， 英 国 首相 戈 登 ， 布朗 才 
为 当年 政府 对 图 灵 的 判决 发 表 了 一 份 官方 道歉 声明 。 



































美国 计算 机 协会 以 图 灵 的 名 字 命 名 了 计算 机 界 的 最 高 荣誉 : 图 灵 奖 ( 等 同 于 其 他 
领域 的 诺 贝尔 奖 )， 以 表彰 图 灵 为 计算 机 科学 和 人 工 智 能 所 做 的 开创 性 工作 。 本 章 提 
到 的 许多 科学 家 都 是 图 灵 奖 得 主 。 








2. 计算 复杂 度 

电子 计算 机 从 20 世 纪 50 年 代 开 始 在 社会 上 发 挥 重 要 作用 ， 人 们 需要 某 种 方法 来 衡 
量 要 解决 的 不 同 问题 的 计算 难度 。 第 一 批 方法 的 建立 源 于 科学 家 对 人 类 思考 和 交流 方 
式 的 描述 。 





1943 年 ， 心 理学 家 沃 伦 - 麦 卡 洛克 和 沃尔特 ' 皮 菊 建立 了 一 个 描述 脑 活动 的 模 
型 ， 名 叫 神经 网 (neural net )。20 世 纪 50 年 代 ， 逻 辑 学 家 斯 蒂 芬 ， 克 莱 尼 建立 了 图 灵 
机 的 一 个 受 限 版 本 ， 叫 有 限 自 动机 (C finite automaton )， 并 研究 了 能 被 其 解决 的 问题 的 
属性 。 有 限 自 动机 对 于 描述 简单 机 器 〈 如 卖 汽水 的 机 需 ) 的 控制 逻辑 非常 有 用 ,但 过 
多 的 限制 使 它 无 法 表示 更 复杂 的 算法 。 





























20 志 纪 50 年 代 , 语言 学 家 诺 姆 : 乔 姆 斯 基 试 图 理解 人 类 如 何 生成 英语 或 其 他 语言 
的 句子 。 他 引入 了 如 “上 下 文 无 关 文法 ”( context-free grammar ) 等 方法 ， 可 生成 句子 
的 解析 树 ， 如 下 图 所 示 。 








上 下 文 无 关 文法 对 人 类 语言 句子 的 表述 有 一 定 合理 成 分 , 但 不 够 完整 。 目 前 语言 
学 界 对 哪 种 语法 更 适 于 表述 语言 一 一 抑或 这 种 语法 究竟 存在 与 否 还 存在 争议 。 





而 在 描述 和 解析 编程 语言 及 XML 等 计算 机 生成 的 数据 文件 等 方面 , 上 下 文 无 关 文 
法 十 分 好 用 。 尽 管 如 此 ， 它 和 有 限 自动 机 一 样 ， 都 不 能 表述 我 们 对 高 效能 计算 的 直观 
概念 。 
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Sentence (句子 ) 


Noun phrase 《名 词性 短语 ) Verb phrase (动词 性 短语 ) 


dam A A 


Article Adjphrase Noun Verb Propositional phrase 




















( 冠 词 ) (形容 词性 短语 ) (名 词 ) (动词 ) (介词 短语 ) 
~ dS 
Proposition Noun phrase (名 词性 短语 ) 





Adj. Adj. (介词 ) 

FA) (形容 词 ) DM ms 
Article Adj. Noun 
( 冠 词 ) (形容 词 ) Cia) 











一 、 




















The quick brown fox jumped | over the lazy dog. 


(敏捷 的 棕色 狐狸 跳 过 了 那 条 懒 洋洋 的 狗 。) 
图 5-2 解析 树 

人 们 还 引入 了 很 多 其 他 的 模型 ,但 这 个 领域 的 突破 性 进展 发 生 在 1962 年 ， 由 纽约 
州 斯 克 内 克 塔 过 通用 电气 公司 科研 实验 室 的 尤 里 斯 - 哈 特 马 尼 斯 和 理 查 德 : 斯 特 恩 斯 
取得 。 他 们 想 出 一 种 绝妙 的 方式 ， 来 表示 计算 机 程序 解决 问题 的 能 力 : 看 看 随 着 问题 
描述 的 规模 的 扩大 , 计算 机 算法 所 需 的 运行 时 间 和 存储 空间 发 生 了 多 大 的 变化 就 可 以 
了 。 两 人 在 1965 年 发 表 的 论文 “ 论 算法 的 计算 复杂 度 ”( On the Computational Complexity 
of Algorithms ) 推动 了 计算 复杂 度 这 个 研究 领域 的 诞生 。 因 为 这 些 工作 ， 哈 特 马 尼斯 
和 斯 特 恩 斯 获得 了 1993 年 的 图 灵 奖 。 
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20 世 纪 60 年 代 , 计算 复杂 度 领域 出 现 了 两 个 不 同 的 研究 方向 。 其 中 一 个 是 研究 在 给 
定 的 时 间 、 存 储 空间 和 显 式 计算 模型 下 ， 哪 些 问 题 能 够 被 解决 ， 而 哪些 不 能 。 另 一 个 研 
究 方 向 的 带头 人 是 曼 纽 尔 ' 布 卢 姆 ， 他 在 麻 省 理工 学 院 攻读 博士 学 位 期 间 的 工作 采取 
了 一 种 非常 抽象 的 方法 , 其 研究 结果 不 仅 不 依赖 于 任何 特定 的 模型 , 甚至 不 依赖 于 特定 
种 类 的 资源 ， 如 时 间或 存储 空间 。 这 两 种 方法 都 没有 抓 住 高 效能 计算 的 真正 本 质 。 






























































3. P 和 NP 














高 效能 计算 的 正确 定义 来 自 20 址 纪 60 年 代 的 两 篇 论文 ， 分 别 是 杰克 埃 德 蒙 效 的 
“IE, BRIER” (Paths, Trees and Flowers ) 和 艾 伦 … 科 巴 姆 的 “函数 的 内 在 计算 
难度 ”( The Intrinsic Computational Difficulty of Functions )。 

















埃 德 蒙 效 论文 最 重要 的 贡献 是 给 出 了 配对 问题 的 首 个 有 效 算 法 ， 这 在 第 3 章 讨 论 
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过 了 。 论 文 有 一 节 叫 “ 题 外 话 ”， 埃 德 蒙 效 在 里 面 讨论 了 指数 和 代数 级 别 的 区 别 ， 不 
过 他 不 建议 为 算法 的 效率 设 定 任何 严格 的 标准 : 


需要 稍微 解释 一 下 用 到 的 “高 效能 算法 ”这 个 词 …… 我 没有 准备 好 给 出 
严格 的 理论 体系 赋予 其 正式 的 含义 ， 况 且 这 篇 文章 的 上 下 文 也 不 适合 这 样 
做 …… 实 践 中 ， 区 分 代数 级 别 和 指数 级 别 的 重要 性 ， 要 远大 于 区 分 可 计算 与 
不 可 计算 的 重要 性 …… 如 果 硬 要 制定 一 些 严格 的 标准 ， 可 能 会 在 实践 上 阻碍 
有 用 的 算法 的 研发 ， 因 为 这 些 算法 要 么 是 未 知 的 ， 要 么 理论 上 与 标准 不 
符 …… 无 论 如 何 ， 为 鼓励 人 们 去 搜寻 优秀 而 实用 的 算法 ， 很 重要 的 一 点 是 认 
识 到 : 质疑 此 种 标准 的 存在 价值 在 数学 上 是 有 一 定 道理 的 。 


埃 德 蒙 效 的 “代数 级 别 ” 正 是 P 所 代表 的 我 们 能 有 效 计 算 的 问题 。 正 如 埃 德 蒙 效 
建议 的 , 虽然 有 必要 用 正式 的 方法 来 定义 “是 否 P= NP ”等 问题 , 但 我 们 心中 也 应 该 
对 高 效能 计算 有 一 种 非 正式 的 概念 ， 而 这 也 是 我 想 在 本 书 中 表达 的 一 种 观点 。 


























科 巴 姆 同样 独立 地 定义 了 P， 并 讨论 了 为 什么 这 个 概念 很 有 用 。 








— 








有 很 多 原因 让 类 型 P 成 为 一 个 自然 而 然 的 概念 。 首 先 ， 如 果 我 们 对 各 种 通用 类 型 
的 计算 机 器 分 别 做 一 个 形式 化 的 表述 ， 会 发 现 总 是 离 不 开 几 个 相同 的 定义 明确 的 函 
数 。 据 此 ， 我 们 能 给 出 一 个 数学 的 表征 P， 并 相信 它 能 正确 地 表征 那些 定义 得 不 那么 
正式 的 类 别 。 














和 可 计算 性 的 定义 一 样 ， 类 型 P 并 不 依赖 于 计算 模型 的 特定 细节 。 
科 巴 姆 也 提醒 人 们 注意 : 
这 个 问题 让 人 想起 如 何 形式 化 地 定义 “效率 ”这 个 概念 。 虽 然 二 者 很 明 
显 有 关联 ， 但 是 强调 的 方面 不 同 ， 这 里 主要 关注 的 是 计算 过 程 的 物理 方面 。 
科 巴 姆 也 许 认 识 到 将 来 可 能 出 现 不 属于 他 所 说 的 类 型 P 的 计算 模型 。 随 机 化 和 量 
子 计算 模型 的 研发 表明 ， 我 们 也 许 无 法 对 高 效能 计算 有 一 个 固定 的 概念 。 

















之 后 在 1971 年 ， 斯 带 芬 . 库 克 发 表 的 论文 定义 了 NP 即 我 们 能 很 快 验证 的 问 
题 )、P/NP 问 题 ， 以 及 第 一 个 NP 完全 问题 。 一 年 后 理 查 德 . 卡 普 在 论文 中 给 出 了 一 长 
串 属于 NP 完全 的 问题 。 
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1972 年 , IBM 的 T.J. 华 生 研究 中 心 召开 了 一 次 有 关 计 算 机 的 计算 复杂 度 的 座谈 会 ， 
这 次 会 议 主 要 因为 卡 普 的 论文 而 被 世人 记 住 。 组 织 者 在 会 议 结束 时 安排 了 小 组 讨论 ， 
探讨 这 个 领域 的 未 来 发 展 。 其 中 一 个 问题 是 :“ 如 何 把 原来 零散 的 下 确 界 结论 以 及 某 
些 算法 整合 起 来 ， 发 展 成 一 个 更 加 统一 的 理论 ?” ”对 于 这 个 问题 的 答案 , 包括 卡 普 本 
人 在 内 的 小 组 成 员 都 没 太 有 把 握 ， 只 是 模糊 地 感觉 到 它 可 能 与 库 克 和 卡 普 的 论文 有 
关 ， 与 P、NP、 可 归 约 性 以 及 之 后 的 NP 完 全 性 理论 等 有 关 。 






























































卡 普 意识 到 他 们 需要 为 这 个 新 领域 起 个 好 名 字 : 

“计算 复杂 度 ” 这 个 名 字 太 宽泛 了 ， 它 包括 了 布 卢 姆 和 其 他 人 的 工作 ， 
而 现在 我 们 还 没 法 把 他 们 的 工作 涵盖 进来 ;“ 混 凝 土 计算 复 杂 度 ” 听 起 来 好 
像 土木 工程 的 分 支 "; “计算 机 计算 的 复杂 度 ” 听 起 来 又 不 是 很 准确 。 





后 来 这 个 领域 就 叫做 计算 复杂 度 。 P/NP 问 题 的 重要 性 很 快 显现 , 抢 尽 了 这 个 领域 
其 他 研究 方向 的 风头 。 抽 象 复杂 度 给 人 的 感觉 更 不 靠 谱 了 。 连 曼 纽 尔 ' 布 卢 姆 本 人 也 
改变 了 研究 方向 ， 开 始 转 攻 密 码 学 和 程序 检验 。 布 卢 姆 因 其 在 20 世 纪 60、70 和 80 年 代 
所 做 的 广泛 研究 而 获得 1995 年 的 图 灵 奖 。 很 多 年 后 ， 当 被 问 及 他 在 20 世 纪 70 年 代 改 变 
研究 方向 的 原因 时 ， 布 卢 姆 简单 地 答 道 :“ 库 克 是 对 的 。 
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当年 苏联 的 “理论 控制 论 ” 学 界 活跃 着 很 多 重要 的 人 物 ， 而 我 们 的 故事 将 集中 介 
绍 其 中 的 三 位 ， 他 们 分 别 代表 处 理 蛮 力 搜索 的 三 种 方式 。 














1. 谢 尔 盖 ， 雅 布 隆 斯 基 ， 他 首次 将 亦 力 搜索 的 研究 聚焦 于 寻找 实现 特定 计算 函数 
的 最 小 电路 ， 但 他 的 权力 欲 和 傲慢 阻碍 了 俄罗斯 的 计算 复杂 度 科学 的 发 展 。 
2. 安 德 烈 . 柯 尔 英 哥 洛 夫 ， 他 是 伟大 的 俄罗斯 数学 家 ， 主 张 通过 代数 信息 来 衡量 









































3. 柯 尔 莫 哥 洛 夫 的 学 生 列 昂 尼 德 ， 莱 文 ， 他 独自 研究 发 现 了 PNP 问 题 和 NP 完 全 
问题 ， 但 是 由 于 政治 原因 ， 他 甚至 无 法 在 祖国 得 到 博士 学 位 。 














(D concrete 除 了 “实际 ”还 有 “混凝土 ”的 意思 。 一 一 译 者 注 
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1. 谢 尔 盖 ， 雅 布 隆 斯 基 


俄罗斯 的 计算 学 研究 被 称 为 理论 控制 论 , 该 学 科 直 到 20 世 纪 50 年 代 电 子 计 算 机 在 
军事 上 开始 发 挥 重要 作用 时 才 正 式 起 步 。 谢 尔 盖 ， 弗 谢 沃 治 多 维 奇 ' 雅 布 隆 斯 基 生 于 
1924 年 的 莫斯科 ， 二 战 时 曾 在 苏联 军队 服役 ， 战 后 到 莫斯科 国立 大 学 学 习 数 学 。 他 于 
1953 年 获得 博士 学 位 ， 导 师 是 俄罗斯 可 计算 性 领域 的 先驱 彼得 诺 维 科 夫 。 雅 布 隆 斯 
基 和 诺 维 科 夫 的 男 一 个 学 生 阿 列 克 谢 * 李 雅 普 诺 夫 组 成 研究 小 组 ， 在 莫斯科 国立 大 学 
举办 了 一 系列 关于 人 逻辑 函数 的 研讨 会 。 他 们 的 小 组 成 了 俄罗斯 计算 理论 的 研究 中 心 。 



































































































































第 4 章 提 到 的 可 满足 性 问题 的 处 理 对 象 是 由 基本 逻辑 运算 符 AND `.OR 和 NOT 组 合成 
的 逻辑 表达 式 。 我 们 甚至 可 以 用 一 串 AND 、OR 和 NOoT 来 表达 计算 过 程 。 有 些 问题 只 需 
要 少量 的 逻辑 运算 符 组 成 的 “电路 ”"， 而 其 他 问题 需要 大 规模 的 电路 才能 运算 。 谢 尔 
盖 : 雅 布 隆 斯 基 在 20 世 纪 50 年 代 研究 了 这 个 概念 ， 我 们 今天 称 之 为 电路 复杂 性 。 
































信息 论 创始 人 ， 美 国人 克 劳 德 . 香农 证 明 某 些 逻 辑 函 数 对 应 复杂 度 非常 高 的 电 
路 。 雅 布 隆 斯 基 则 研究 了 生成 这 些 函 数 的 实际 难度 。 听 起 来 是 个 很 困难 的 任务 , [HE 
Us E. P. NP 的 一 个 强化 版 本 就 意味 着 对 于 某 些 描述 起 来 很 简单 的 搜索 问题 ， 不 存在 
小 规模 的 电路 可 以 计算 它们 。 


























雅 布 隆 斯 基 首 先 指出 ,根据 香农 的 结论 ， 随 机 生成 的 函数 对 应 的 电路 的 复杂 度 接 
近 最 大 值 。 接 下 来 他 研究 了 如 何不 用 随机 过 程 就 能 找到 这 样 的 函数 。 需 要 蛮 力 搜索 全 
部 函数 吗 ? 他 证 明 任何 能 生成 具有 接近 最 大 复杂 度 函 数 的 过 程 ， 必 须 内 散 所 有 子 数 。 
那么 从 某 种 意义 上 讲 ， 任 何 能 生成 高 难度 函数 的 过 程 都 能 经 过 修改 ， 以 生成 任意 其 他 
的 函数 。 雅 布 隆 斯 基 提 出 ， 这 意味 着 蛮 力 搜索 是 必要 的 ， 因 为 在 生成 高 难度 函数 的 过 
程 中 ， 必 须 生成 每 一 个 可 能 的 函数 。1959 年 雅 布 隆 斯 基 将 他 的 论文 命名 为 “ 论 在 解决 
电路 理论 的 某 些 问题 时 不 可 能 排除 蛮 力 搜索 ”( On the Impossibility of Eliminating 


Perebor in Solving Some Problems of Circuit Theory )。 



























































雅 布 隆 斯 基 虽 然 证 明了 一 个 重要 的 结论 ,但 他 的 解释 容易 误导 人 。 不 能 根据 “从 
一 个 高 难度 函数 能 生成 任意 函数 ”， 就 推出 “生成 高 难度 函数 必须 生成 所 有 函数 "。 雅 
布 隆 斯 基 的 结论 对 于 寻找 高 难度 函数 的 计算 复杂 度 没有 什么 实际 作用 。 雅 布 隆 斯 基 的 
学 生 佐 拉夫 勒 夫 在 1960 年 发 表 的 一 篇 论文 标题 同样 令 人 印象 深刻 :“ 论 不 可 能 通过 茶 
种 类 型 的 算法 构造 布尔 函数 的 最 小 析 取 范式 ”( On the Impossibility of Constructing 
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Minimal Disjunctive Normal Forms for Boolean Functions by Algorithms of a Certain 
Class )。 这 篇 论文 同样 没有 谈 到 代数 运算 复杂 度 的 问题 。 这 些 研究 工作 实际 上 和 P/NP 
问题 的 研究 没有 什么 关系 。 




















当年 的 苏联 不 仅 在 经 济 上 集权 ,在 学 术 活 动 上 也 是 如 此 。 雅 布 隆 斯 基 断 定 他 自己 
的 研究 圆满 解决 了 蛮 力 搜索 问题 ， 所 以 他 强力 压制 在 这 个 方向 上 的 进一步 研究 ,特别 
是 对 计算 复杂 度 和 算法 的 研究 。 雅 布 隆 斯 基 后 来 进入 了 苏联 协调 和 控制 数学 研究 的 数 
学 委员 会 ， 成 为 其 中 颇 有 影响 力 的 成 员 ， 也 在 20 世 纪 60 年 代 造 成 了 不 少 的 争端 ， 后 面 
将 会 讲 到 。 























2. 安 德 烈 ， 柯 尔 莫 哥 洛 夫 




















安 德 烈 . 柯 尔 莫 哥 洛 夫 于 1903 年 出 生 在 俄罗斯 坦 波 夫 市 。1920 年 他 考 人 莫斯科 国 
立 大 学 ， 最 开始 学 的 不 是 数学 ， 而 是 历史 学 。 他 研究 的 问题 是 : 俄罗斯 在 中 世纪 的 征 
税 工作 是 以 户 为 单位 还 是 以 村 为 单位 来 开展 的 。 他 分 析 了 税收 数据 , 证 明 如果 以 村 为 
单位 来 收 税 ， 那 么 对 数据 的 描述 会 更 简单 一 些 。 他 把 这 些 结果 呈 交 到 历史 系 ， 得 到 了 
极 大 的 赞扬 。 于 是 他 询问 是 否 能 发 表 论 文 ， 得 到 的 回答 却 是 :“ 你 只 有 一 个 证 据 。 在 
历史 期 刊 上 发 表 文 章 至 少 需要 两 个 证 据 来 支持 你 的 假说 。” 于 是 柯 尔 莫 哥 洛 夫 放弃 历 
史 ， 转 而 研究 那些 一 个 证 据 就 足够 的 领域 。 柯 尔 莫 哥 洛 夫 选 择 了 数学 ， 并 通过 努力 ， 
成 为 20 址 纪 苏 联 乃 至 全 世界 最 伟大 的 数学 家 , 他 对 几乎 所 有 的 数学 领域 都 作出 了 基础 
性 的 贡献 。 
























































i 问题 就 在 这 
999999 Ji 你 确定 生成 ”里 ， 你 不 能 
| 的 是 随机 数 ? 确定 生成 的 


看 ， 这 是 我 们 的 


随机 数 生成 器 。 
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柯 尔 莫 哥 治 夫 对 理解 概率 和 随机 性 的 热忱 , 直接 促成 了 一 个 简单 却 伟大 得 不 可 思 
议 的 想法 。 比 如 下 面 几 串 数字 : 
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口 999 999 999 999 999 999 999 999 999 999 999 999 999 999 999 999 999 
Q 707 106 781 186 547 524 400 844 362 104 849 039 284 835 937 688 474 
D 982 922 216 207 267 591 232 795 977 564 268 549 473 337 889 037 097 











中 有 一 串 是 通过 随机 数 生成 器 生成 的 ， 其 他 两 串通 过 其 他 方法 生成 。 上 面 每 个 数字 序 
列 发 生 的 可 能 性 都 是 相同 的 ， 为 什么 要 认为 一 个 序列 比 其 他 序列 更 加 “随机 ” 呢 ? 在 
继续 往 下 读 之 前 ,请 大 家 先 猜 猜 哪 串 数字 真 的 是 随机 生成 的 。 

















很 难 认为 一 个 全 是 “9” 的 序列 是 随机 生成 的 。 第 二 个 序列 可 能 有 人 知道 它 是 0.5 
的 平方 根 小 数 点 后 数字 的 前 50 位 。 所 以 第 三 个 数 才 是 随机 选择 的 。 








柯 尔 莫 哥 洛 夫 认识 到 ， 一 个 序列 的 随机 性 大 小 可 以 通过 “最 少 需要 多 少 字 数 来 描述 
它 ” 来 衡量 。 第 一 个 序列 的 描述 是 “50 个 9”。 第 二 个 序列 是 “1/ V2”。 而 对 于 第 三 个 数 ， 
最 短 的 描述 只 能 是 982 922 216 207 267 591 232 795 977 564 268 549 473 337 889 037097。“ 描 
述 ”是 一 个 不 正规 的 概念 ， 柯 尔 莫 哥 洛 夫 通 过 计算 机 程序 的 表述 把 它 正 规 化 了 。 
























































类 似 的 想法 在 稍 早 也 先后 被 两 个 美国 人 提出 过 ,他 们 分 别 是 雷 . 索 洛 莫 诺 夫 (出 
生 于 克利 夫 兰 州 ， 厌 恶 自己 的 俄罗斯 姓氏 ) 和 格 里 高 利 * 蔡 廷 。 柯 尔 贡 哥 洛 夫 及 其 弟 
子 则 深化 了 这 个 概念 ， 所 以 这 个 衡量 标准 被 称 为 “ 柯 尔 莫 哥 洛 夫 复 杂 度 ”。 




















随机 序列 就 是 指 最 短 描述 是 本 身 的 序列 ， 比 如 
982 922 216 207 267 591 232 795 977 564 268 549 473 337 889 037 097 


通过 随机 选择 每 一 位 数 很 容易 就 能 生成 随机 序列 。 没 有 随机 数 就 没有 这 些 随机 序 
列 。 不 存在 非 随 机 化 的 算法 能 生成 任意 长 度 的 随机 序列 。 我 甚至 不 知道 





982 922 216 207 267 391 232 795 977 564 268 549 473 337 889 037 097 





是 否 真 的 是 一 个 随机 序列 ， 因 为 必须 要 测试 所 有 比 它 短 的 描述 方式 ， 而 有 些 表述 方式 
可 能 非常 复杂 。 





柯 尔 莫 哥 治 夫 复杂 度 的 理论 背景 深厚 ， 并且 在 机 器 学 习 、 算 法 分 析 和 计算 复杂 度 
等 多 个 领域 有 广泛 应 用 。 虽 然 它 本 身 没 有 直接 涉及 P/NP 问 题 ， 但 是 通过 对 它 的 研究 ， 
柯 尔 莫 哥 洛 夫 的 学 生 列 昂 尼 德 ， 莱 文 直接 导出 了 PNP 问 题 。 
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3. 列 昂 尼 德 。 莱 文 











1961 年 ， 李 雅 普 诺 夫 从 莫斯科 国立 大 学 转 到 新 西伯 利 亚 国立 大 学 任教 ， 在 那里 他 



































建立 了 理论 控制 学 系 。 新 西伯 利 亚 市 距离 莫斯科 有 2800 公 里 之 遥 ， 是 俄罗斯 第 三 大 城 





市 


， 也 是 西伯 利 亚 最 大 的 城市 。 












































系 里 的 老师 大 部 分 是 雅 布 隆 斯 基 和 李 雅 普 诺 夫 以 前 的 学 生 , 来 自 莫斯科 。 新 组 建 












































的 理论 控制 学 系 很 快 成 为 俄罗斯 理论 控制 学 的 第 二 大 研究 中 心 。 鲍 里 斯 - 特 拉 腾 布 罗 
在 40 岁 就 已 经 是 这 个 领域 的 资深 研究 者 ,他 在 中 心 建成 之 时 就 已 加 入 ,并 很 快 成 为 领 
军人 物 。1962 年 ，Y. M. 巴 效 丁 从 里 加 市 拉脱维亚 大 学 获得 博士 学 位 ， 并 加 入 了 新 西 
伯 利 亚 的 研究 中 心 。 特 拉 腾 布 罗 开始 和 巴 效 丁 合作 ,研究 计算 复杂 度 的 基础 理论 ， 许 
多 拉脱维亚 和 新 西伯 利 亚 的 学 生 慕名 而 来 。 在 20 世 纪 60 年 代 ， 他 们 开始 建立 一 个 复杂 
度 的 算法 理论 ， 类 似 于 同时 期 西方 的 研究 。 
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但 苏联 的 计算 复杂 度 理论 的 发 展 并 不 顺利 ， 正 如 特 拉 腾 布 罗 1984 年 写 的 那样 : 





我 们 与 “主流 ”的 控制 论 研究 者 们 ( 主要 是 雅 布 隆 斯 基 ) 之 间 的 关系 恶 
化 了 ， 对 此 感到 担心 。 他 们 对 于 将 算法 理论 引入 复杂 度 研 究 领 域 的 态度 十 分 
消极 …… 他 们 不 相信 计算 复杂 度 和 算法 复杂 度 在 变 力 搜索 领域 起 到 的 作用 。 
这 些 学 术 上 的 分 层 很 可 能 因为 变 力 搜索 上 的 争议 而 加 深 , 特别 是 当 雅 布 隆 斯 
基 在 那样 一 个 协调 和 控制 数学 研究 的 组 织 中 担任 高 位 之 后 。" 


柯 尔 葛 哥 洛 夫 于 1963 年 夏天 访问 了 新 西伯 利 亚 ， 他 和 特 拉 腾 布 罗 分 享 了 学 术 成 


， 探 讨 了 算法 理论 如 何 促进 对 信息 和 复杂 度 的 理解 。 

















在 那 次 访问 之 后 ， 柯 尔 英 哥 洛 夫 很 快 到 了 基辅 大 学 ， 并 访问 了 一 个 为 数学 和 物 








理学 神童 专 设 的 高 中 寄宿 学 校 。 他 随便 问 了 几 个 问题 ， 很 多 问题 都 被 一 个 叫 列 晶 尼 


E 
德 











: 菜 文 的 15 岁 孩子 解答 了 。 柯 尔 莫 哥 治 夫 后 来 邀请 莱 文 到 莫斯科 大 学 跟 他 学 习 。 


莱 文 在 研究 生 期 间 的 杰出 工作 分 为 两 个 方向 。 











首先 ， 莱 文 发 明了 一 个 通用 的 搜索 算法 。 假 设 Alice 对 Bob 说 她 有 能 快速 求解 团 问 























题 的 算法 ， 但 是 不 告诉 Bob 是 什么 算法 。 莱 文 的 技巧 能 让 Bob 创 造 出 一 个 几乎 和 Alice 





(D B. A. Trakhtenbort, “A Survey of Russian Approaches to Perebor Algorithms," Annals of the History of 
Computing 6, no. 4 (October 1984). 
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的 算法 一 样 快 的 算法 ， 而 他 不 需要 知道 Alice 的 算法 具体 是 什么 。 莱 文通 过 柯 尔 莫 哥 洛 
夫 复 杂 度 的 一 个 变种 发 展 了 自己 的 理论 ， 基 本 上 是 尝试 了 所 有 合理 的 方式 ， 才 取得 了 
这 个 成 果 。 












































对 搜索 的 研究 使 莱 文 转 而 思考 那些 能 反映 搜索 本 质 的 问题 ， 于 是 他 引入 了 “通用 
搜索 问题 ”的 概念 ， 这 个 概念 基本 相当 于 库 克 提出 的 NP 完 全 性 。 莱 文 列 出 了 6 个 通用 
搜索 问题 ， 其 中 就 包括 可 满足 性 问题 ， 从 而 正式 建立 了 P/NP 问 题 。 




















在 莱 文 取得 的 这 两 项 令 人 惊叹 的 成 就 中 , 仅 第 二 项 几乎 就 可 以 跟 为 库 克 廊 得 图 灵 
奖 的 那 篇 论文 媲美 。 然 而 柯 尔 莫 哥 洛 夫 却 认为 两 个 结果 无 法 分 开发 表 ， 于 是 他 强迫 莱 
文 把 它们 写 在 一 篇 论文 里 。 当 时 俄罗斯 的 数学 出 版 物 的 风格 导致 精简 的 论文 更 受 欢 
迎 ， 文 中 基本 不 会 给 出 支持 结论 的 证 据 的 细节 。 莱 文 把 这 种 风格 发 挥 到 了 极致 ， 将 两 
项 成 果 写 在 了 一 篇 只 有 两 页 的 论文 里 。 





















































莱 文 在 苏联 申请 博士 学 位 的 时 候 , 没有 把 这 篇 杰作 包括 在 论文 集 里 。 当 时 所 有 
苏联 年 轻 人 都 是 苏联 共产 主义 青年 团团 员 。 莱 文 经 常 在 共青团 的 活动 中 调皮 捣蛋 ， 
他 低估 了 这 些 行 为 的 后 果 。 这 些 行为 最 终 导致 他 没有 被 授予 博士 学 位 ， 因 为 政治 不 
合格 。 








莱 文 在 苏联 无 法 摆脱 政治 问题 的 纠 强 ， 他 想方设法 在 1978 年 移民 到 了 美国 。 艾 伯 
特 ' 梅 耶 将 他 录取 为 麻 省 理工 学 院 的 研究 生 ， 由 于 他 以 前 的 研究 工作 太 厉 害 ， 第 二 年 
就 拿 到 了 博士 学 位 。 后 来 莱 文 到 波士顿 大 学 担任 教授 ， 直 到 今天 。 




















莱 文 的 工作 在 20 世 纪 70 年 代 中 期 才 被 美国 所 知晓 ， 那 时 PINP 问 题 已 经 广 受 关注 。 
莱 文 没 能 分 享 库 克 1982 年 的 网 灵 奖 ,而 直到 20 世 纪 80 年 代 未 期 ,人 们 才 把 NP 完 全 性 的 
早期 结果 称 为 库 克 - 莱 文 定理 。 















































20 世 纪 80 年 代 后 ， 苏 联 与 美国 的 关系 开始 缓和 。 一 名 俄罗斯 学 生 亚历山大 - 拉 效 
波 洛 夫 为 一 种 通过 电路 复杂 度 理论 来 证 明 P oe NP 的 方法 做 出 了 重要 贡献 ,这 个 故事 我 
们 留 到 第 7 章 再 讲 。 






































随 着 苏联 的 解体 和 互联 网 的 崛起 ， 俄 罗斯 数学 研究 者 的 工作 不 再 与 世 隔绝 。 计 算 
复杂 度 领 域 真正 成 为 全 球 性 的 研究 课题 。 
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1956 年 ， 库 尔 特 ' 哥 德 尔 写 信 给 约翰 ， 汉 “' 诺 依 曼 ， 后 者 是 计算 机 科学 和 其 他 许 
多 领域 的 先驱 。 在 这 封 ( 用 德语 写 的 ) 信里 ， 哥 德尔 讨论 了 可 满足 性 问题 ， 并 用 一 种 
不 同 的 术语 规范 化 了 P/NP 间 题 。 他 提出 如 果 我 们 生活 在 P= NP 的 世界 里 ， 那 么 “ 数 
学 家 思考 “是 或 和 否 ” 的 思想 工作 将 完全 由 机 器 来 代替 ……' 而 我 个 人 认为 ， 这 完全 是 有 
可 能 发 生 的 "。 这 封 信 的 写作 时 间 比 库 克 和 莱 文 的 论文 发 表 早 15 年 。 



















































































我 们 不 知道 汉 诺 依 曼 是 否 回复 了 这 封 信 ， 其 至 不 知道 他 是 否 看 到 了 它 。 冯 … 诺 
依 曼 那 时 已 经 身 患 癌症 ,不 久 就 于 1957 年 辞世 。 这 封 信 和 则 直到 20 志 纪 80 年 代 才 为 科学 
界 所 知 。 哥 德尔 在 1978 年 去 世 ， 然 而 他 晚年 已 经 神志 不 清 ， 无 法 注意 到 库 克 只 是 重 述 
了 他 提出 的 问题 。 




















既然 是 哥 德 尔 早 于 库 克 和 莱 文 发 现 了 P/NP 问 题 , 为 什么 我 们 不 把 P= NP RH 
德尔 问题 "， 以 肯定 他 的 贡献 呢 ” 因 为 科学 领域 遵循 的 是 哥伦布 原理 : 哥伦布 出 名 并 
不 是 因为 他 第 一 个 发 现 了 美洲 ， 而 是 因为 他 最 后 一 个 发 现 了 美洲 。 哥 德尔 本 人 也 不 是 
没有 问题 。 他 自己 都 没有 意识 到 当年 向 汉 : 诺 依 曼 提 出 的 这 个 问题 的 重要 性 ,不 然 他 
不 会 在 之 后 的 任何 一 个 公开 场合 都 没有 提出 这 个 问题 。 库 区 和 莱 文 仍然 是 率先 发 表 论 
文 ， 并 向 学 术 界 呈 现 PINP 问 题 的 人 。 
























































为 纪念 哥 德 尔 为 逻辑 学 作出 的 黄 基 性 贡献 以 及 哥 德 尔 的 这 封 重要 信件 ,理论 计算 
机 科学 界 于 1993 年 设立 了 哥 德 尔 奖 ， 表 袁 该 领域 近期 发 表 的 杰出 研究 论文 。 
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我 们 怎么 判断 一 个 科学 理念 是 自然 产生 的 〈 就 如 同 造物 主创 造 的 一 样 )， 还 是 由 
人 类 的 主观 活动 产生 的 呢 ? 假设 我 们 发 现存 在 火星 文明 , 其 科技 水 平 与 我 们 地 球 文明 
的 水 平 相当 。 如 果 在 火星 文明 中 有 一 个 与 地 球 文明 相同 或 相近 的 理念 , 那么 这 个 理念 
应 该 是 自然 产生 的 ， 因 为 它 分 别 来 源 于 两 个 独立 的 文明 。 




















当然 不 存在 火星 文明 来 和 地 球 文明 做 比较 ， 所 以 只 能 想象 一 下 。 假设 火 星人 的 计 
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算 机 器 叫 Exigius"， 它 和 图 灵机 有 本 质 的 区 别 ， 但 是 两 者 有 着 相同 的 计算 能 力 。 那 么 
火星 版 的 丘 奇 - 图 灵 论 题 是 : 一 切 可 计算 的 事物 都 能 被 Exigius 计 算 。 所 以 从 火星 人 的 
角度 看 ， 图 灵机 不 是 自然 产生 的 ， 而 计算 这 个 概念 是 自然 产生 的 。 











对 于 P/NP 问 题 的 自然 性 , 我 们 不 需要 火星 人 来 证 明 。 当 年 苏联 和 北美 的 研究 者 在 
彼此 隔绝 的 情况 下 ， 发 现 了 同一 个 P/NP 间 题 以 及 NP 完全 问题 。 他 们 的 研究 动机 不 同 : 
在 东方 ， 人 们 试图 理解 蛮 力 搜索 的 必要 性 ; 而 在 西方 ， 人 们 则 希望 理解 高 效能 计算 的 
力量 。 他 们 沿 着 各 自 的 研究 之 路 ， 最 终 来 到 了 同样 的 地 方 ， 一 个 在 15 年 前 就 被 库 尔 
FE 哥 德 尔 捷足先登 的 地 方 。 














类 似 地 , 假想 中 的 火星 人 应 该 也 会 发 现 P/NP 问 题 (或 者 类 似 的 问题 , 但 愿 他 们 还 
没有 先 我 们 一 步 解决 这 个 问题 )， 并 且 很 可 能 他 们 也 认为 这 个 问题 是 自然 产生 的 ， 而 
且 非 常 重要 。 




















(D Exigius 这 个 名 字 来 自 美国 科幻 电视 连续 剧 My Favorite Martian, PXH (KEAT 2s 
一 一 译 者 注 
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处 理 困 难 的 问题 


在 第 2 章 ， 我 们 看 到 了 P= NP 的 美好 世界 。 生 活 将 如 此 轻松 ， 人 们 可 以 对 一 切 进 
行 最 优化 ， 了 人 解 万 事 万 物 。 我们 将 拥有 让 人 心 想 事 成 的 机 带 。 这 一 切 太 过 美好 了 ， 以 
至 于 有 点 吓人 ， 而 且 几 乎 肯定 是 不 切实 际 的 幻想 。 

















我 们 更 可 能 生活 在 一 个 相对 混乱 的 世界 , 一 个 Pz NP 的 “不 优雅 ”的 世界 。 即 使 
P= NP ， 在 找到 解决 NP 问题 的 算法 之 前 ,我们 还 是 一 样 生活 在 Pz NP 的 世界 。 那 么 
对 于 那些 我 们 不 能 有 效 求解 的 问题 ， 我 们 该 怎么 处 理 ? 直接 放弃 吗 ? 














有 时 候 我 们 不 得 不 处 理 困 难 的 问题 。 哈 利 在 Acme 制 造 厂 担任 主 调度 师 。 老 板 艾 
米 让 哈 利 安排 机 器 的 调度 方案 , 来 生产 Acme 最 新 的 手机 A-Phone， 并 要 求 使 用 的 时 间 
尽 可 能 短 。 哈 利 读 了 本 书 开头 的 几 章 后 回答 :“ 对 不 起 ， 但 那个 问题 是 NP 完 全 的 。 连 
很 多 著名 的 计算 机 科学 家 都 不 相信 这 类 问题 存在 有 效 的 解决 方法 ， 所 以 我 试 也 是 白 
试 。 我 还 是 去 打 保龄球 吧 。” 艾 米 直接 祝 哈 利 玩 得 开心 ， 然 后 不 用 来 上 班 了 。 








艾 米 很 快 提拔 了 乔治 来 代替 哈 利 。 幸 好 乔治 读 了 本 书 的 这 一 章 ， 然 后 拟 出 了 一 个 
生产 A-Phone 的 调度 方案 。 乔 治 写 出 了 一 个 总 能 找到 最 好 的 调度 方案 的 美妙 算法 吗 ? 
没有 。 但 是 乔治 有 没有 把 事 做 完 ?是 的 。 





NP 完 全 问题 是 难以 驯服 的 野兽 ， 如 果 有 了 =#NP ， 那 我 们 不 可 能 找到 一 个 能 对 所 
有 问题 总 给 出 最 好 方案 的 快速 算法 。 然 而 我 们 不 必 放 弃 ， 本 章 我 们 就 来 看 看 有 哪些 方 
法 能 在 处 理 困 难 问题 时 派 上 用 场 。 











has 





对 于 中 等 规模 的 问题 , 我 们 可 以 用 如 今 非常 快 的 计算 机 遍历 所 有 的 解决 方案 。 我 
们 可 以 采用 一 些 虽然 不 能 包 治 百 病 , 但 对 我 们 关心 的 问题 起 作用 的 算法 。 还 有 的 算法 
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虽然 不 能 给 出 所 有 可 能 方案 中 最 好 的 ， 但 是 能 给 出 一 个 足够 好 的 方案 。 





有 的 时 候 你 想 尽 办 法 也 找 不 到 一 个 NP 完 全 问题 的 解决 方法 。 你 可 以 试 着 解决 一 个 
不 同 的 问题 ， 或 者 干脆 放弃 。 天 涯 何 处 无 芳 草 ， 何 必 在 一 棵 树 上 吊 死 。 
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计算 机 很 快 ， 甚 至 是 你 桌 上 或 口袋 里 的 那些 计算 机 ， 也 快 到 不 可 思议 ， 以 至 于 它 
们 可 以 通过 使 用 “ 蛮 力 ”搜索 所 有 可 能 的 方案 ， 来 解决 一 个 中 等 规模 的 问题 。 

















以 前 可 不 是 这 样 的 。 在 斯 蒂 芬 . 库 克 将 PINP 问 题 呈 献 给 世人 的 1971 年 ， 英 特 尔 公 
司 发 布 了 它 的 第 一 个 微 处 理 器 芯片 一 一 Intel 4004。Intel 4004 是 第 一 个 包含 整个 CPU 的 
芯片 ， 也 是 第 一 个 商业 化 的 微 处 理 器 。Intel 4004 当 时 的 运行 速度 是 每 秒 执行 92 000 条 


BA 
8o. 









































以 库 克 的 可 满足 性 问题 为 例 ， 设 共有 20 个 变量 ， 考 虑 一 个 简单 的 算法 ， 它 会 遍历 
并 尝试 所 有 让 每 个 变量 分 别 为 TRUE 或 FALSE 的 解 集 。 如 果 验 证 每 个 解 需要 100 步 , 那 
么 我 们 可 以 在 19 分 钟 内 判断 某 个 表达 式 是 否 能 被 满足 。 这 个 时 间 不 是 特别 长 ， 毕 况 用 
20 个 变量 表示 不 了 多 少 内 容 。 























解决 一 个 25 个 变量 的 问题 需 花 费 10 小 时 ， 而 求解 30 个 变量 的 问题 将 超过 13 天 。 一 
个 40 个 变量 的 问题 ， 如 果 按 1971 年 的 计算 能 力 ， 将 算 到 2009 年 。 











这 上段 时 间 里 , 英特尔 每 年 都 会 发 布 很 多 型 号 的 处 理 器 。 让 我 们 从 2009 年 选 一 个 型 
^, Intel i7-870， 它 每 秒 执行 的 指令 数 是 29.3 亿 条 ( 是 Intel 4004 的 3 万 多 倍 )。 用 这 个 
速度 ,求解 40 个 变量 的 问题 将 花费 大 概 10 个 小 时 。 也 就 是 说 ， 如 果 你 在 1971 年 想 求解 
一 个 40 个 变量 的 问题 ,你 可 以 选择 花 38 年 玩 自己 的 手指 ,然后 用 2009 年 的 科技 解决 这 
个 问题 ， 这 比 从 1971 年 就 开始 用 当时 的 科技 来 计算 还 要 快 。 












































针对 某 些 其 他 的 NP 问题 , 算 例 的 规模 可 以 更 大 。NP 完 全 的 旅行 推销 员 问 题 是 指 
找到 访问 许多 个 城市 的 最 短路 线 。 用 所 谓 的 分 割 面 法 ， 我 们 可 以 用 很 短 时 间 解 决 1 万 
个 城市 规模 的 旅行 推销 员 问 题 。 美 国人 口 超过 500 的 城市 共有 13 509 个 ， 图 6-1 是 穿 过 
这 些 城市 的 最 短路 径 。 
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图 6-1 500 人 以 上 城市 的 旅行 推销 员 问 题 
对 于 其 他 的 NP 问题 ， 可 能 性 的 数 日 大 到 连 解决 中 等 规模 的 问题 都 不 太 可 能 。 


虽然 我 们 即将 逼近 计算 机 速度 的 物理 极限 , 但 随 着 摩尔 定律 反映 出 的 芯片 上 核心 
处 理 器 个 数 的 快速 增长 ， 人们 仍然 期 望 计算 机 的 运算 能 力 持续 出 现 戏剧 性 的 增长 。 这 
将 有 助 于 未 来 更 大 规模 的 NP 完 全 问题 得 到 解决 。 然 而 问题 的 复杂 度 也 会 随 着 规模 的 扩 
大 迅速 增长 。 所 以 别 指望 能 在 近期 解决 150 个 变量 的 可 满足 性 问题 , 或 是 找到 2 万 个 城 
5 之 间 的 最 佳 旅行 方案 。 






































6.2 ”局 发 式 方法 





17 世 纪 的 伐木 工 在 测量 中 经 常用 他 们 拇指 的 长 度 来 大 致 度量 1! "英才 ”的 距离 。 拇 
规则 ”这 一 俗语 可 能 就 源 自 于 此 ， 意 思 是 在 决定 某 些 问题 答案 的 过 程 中 使 用 一 种 不 
太 准 确 但 大 致 可 用 的 简化 方法 。 谚 语 “朝霞 不 出 门 ， 晚 霞 行 千里 ”给 出 了 一 种 粗略 但 
通常 相当 可 靠 的 预测 天 气 的 方式 。 摩尔 定律 本 身 也 提供 了 一 种 粗略 地 预测 未 来 计算 机 
的 计算 能 力 的 方法 。 















































计算 机 算法 同样 也 是 一 种 过 程 。 启 发 式 方法 是 一 种 原理 类 似 “ 拇 指 规则 ”的 算 
法 , 虽然 不 能 保证 给 出 正确 的 答案 , 但 可 以 对 大 多 数 你 想 解 决 的 问题 给 出 答案 。 人 
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们 在 认识 到 某 些 问题 是 NP 完 全 问题 之 前 ， 就 给 出 了 它们 的 启发 式 解法 。 几 十 年 来 ， 
我 们 为 解决 各 种 困难 的 问题 发 明了 很 多 复杂 的 启发 式 方法 。 虽然 这 些 方 法 不 适用 于 
任意 一 个 NP 完全 问题 的 所 有 情况 ,但 有 助 于 根据 特定 的 情况 解决 人 们 所 面临 的 部 
分 问题 。 


让 我 们 来 详细 分 析 一 个 地 图 填 色 问题 的 简单 而 强大 的 启发 式 方法 。 在 第 3 章 我 们 
证 明了 为 美国 地 图 填 色 至 少 需要 4 种 颜色 ， 才 能 保证 所 有 接壤 的 州 具有 不 同 的 颜色 。 


加 利 福 尼 亚 、 俄 勒 交 、 爱 达 荷 、 犹 他 、 亚 利 桑 那 这 几 个 州 围绕 着 内 华 达州 成 为 一 
圈 。 至 少 需 要 三 种 颜色 为 加 利 福 尼 亚 、 俄 勒 闪 、 爱 达 荷 、 狂 他、 亚利桑那 这 几 个 州 填 
色 。 而 内 华 达 州 并 非 个 例 。 肯 塔 基 州 周围 围绕 着 田纳西 、 弗 吉 尼 亚 、 西 弗吉尼亚 、 俄 
效 俄 、 印 第 安 纳 、 伊 利 诺 伊 和 密苏里 这 几 个 州 。 同 样 ， 你 需要 至 少 3 种 颜色 填充 这 几 
个 围 成 一 圈 的 州 ， 再 用 第 4 种 颜色 填充 表 塔 基 州 。 





俄勒冈 州 








图 6-2 美国 地 图 


一 张 地 图 只 要 上 面 的 某 个 地 区 被 奇数 个 相 邻 的 地 区 所 环绕 ， 那 么 它 最 少 需要 4 种 
颜色 。 


这 里 有 一 张 亚 美 尼 亚 各 州 的 地 图 。 
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阿塞拜疆 飞 地 





图 6-3 ”亚美尼亚 

只 有 两 个 州 完 全 在 亚美尼亚 内 部 ， 不 与 其 他 国家 接壤 m。 科 泰克 州 ( Kotayk” ) 有 6 

个 邻 州 ， 而 首都 埃 里 温 (Yerevan) 有 4 个 邻 州 。 每 个 不 靠 海 的 州都 有 奇数 个 邻 州 。 所 
以 启发 式 方法 告诉 我 们 ， 也 许 能 用 3 种 方法 为 这 张 地 图 填 色 。 事 实 上 真 的 可 以 。 








阿塞拜疆 飞 地 
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阿塞拜疆 飞 地 





图 6-4 ” 填 色 后 的 亚美尼亚 地 图 
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瑞士 有 5 个 邻 国 : 法 国 、 意 大 利 、 奥 地 利 、 列 支 敦 士 登 和 德国 。 虽 然 邻 国 数 为 5， 


我 们 还 是 可 以 用 3 种 颜色 填充 这 张 地 图 。 
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列支敦士登 将 瑞士 和 奥地利 的 国境 线 分 割 为 两 段 ， 所 以 对 于 地 图 填 色 这 个 问题 ， 
我 们 需要 把 奥地利 算 两 次 。 重 要 的 不 是 邻 国 的 数量 ， 而 是 国境 线 的 数量 。 瑞 士 有 6 段 
国境 线 ，6 是 偶数 。 而 且 只 有 外 于 的 国境 线 才 算数 ， 对 于 那些 完全 位 于 其 他 国家 领土 
内 部 的 国家 (如 意大利 内 部 的 焚 蒂 办 )， 我 们 不 把 它们 的 国境 线 计 算 在 内 。 


如 果 这 个 启发 式 方法 总 能 给 出 正确 的 答案 ,那么 它 将 是 一 个 解决 NP 完全 的 三 色 填 
充 地 图 问题 的 有 效 算法 ， 进 而 我 们 就 有 了 解决 所 有 NP 问题 的 有 效 算法 ， 即 P= NP 。 








读 到 这 里 你 可 能 猜 到 了 ， 这 个 启发 式 方法 不 总 是 有 效 。 
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令 这 个 启发 式 方法 失效 的 反例 有 两 个 。 
1. 地 图 上 有 一 个 湖 将 两 个 地 区 分 隔 开 来 ,如 密歇根 湖 将 伊利 诺 伊 州 和 密 葡 根 州 分 


MEFR, 
2. 地 图 上 有 4 个 以 上 的 地 区 汇聚 于 同一 点 ， 如 亚利桑那 、 新 墨西哥 、 科 罗拉 多 和 
犹他 这 四 个 州 。 











在 填充 美国 地 图 时 这 些 反例 不 重要 ， 因 为 我 们 已 经 知道 填充 美国 地 图 至 少 要 4 种 
颜色 ， 这 其 至 没有 把 填充 湖面 的 蓝 色 计算 在 内 。 








然而 这 个 启发 式 方法 在 现实 世界 中 很 少 失效 。 为 说 明 问题 ， 让 我 们 来 看 看 虚构 的 
敌 友 国 地 图 。 虽 然 每 个 省 都 有 偶数 个 邻 省 ， 但 还 是 不 能 只 用 3 种 颜色 为 敌 友 国 地 图 填 


色 (不 包括 湖面 的 蓝 色 )， 以 确保 两 个 接壤 的 省 的 颜色 不 同 。 

















北 布 拉 特 维 亚 




















图 6-7 敌 友 国 地 图 














每 个 省 都 和 4 个 其 他 的 省 接壤 。 没 有 一 个 省 被 邻 省 围绕 成 环 ， 因 为 有 湖水 从 中 阻 
隔 。 启 发 式 方法 告诉 我 们 可 以 只 用 3 种 颜色 填充 这 11 个 省 ， 但 实际 上 这 不 可 能 ， 只 用 
三 色 必然 导致 邻 省 同色 的 情况 。 启 发 式 方法 在 敌 友 国 能 否 用 三 色 填 充 地 图 的 问题 中 给 
出 了 错误 的 答案 。 











可 满足 性 理论 及 其 应 用 国际 学 术 年 会 ( The International Conference on Theory and 


Applications of Satisfiability Testing ) 是 可 满足 性 问题 相关 领域 研究 人 士 的 一 个 交流 和 
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展示 的 平台 , 尤其 重视 优秀 的 启发 式 方法 。 会 议 组 织 了 SAT 竞赛， 比拼 各 种 计算 机 算 
法 求解 可 满足 性 问题 的 能 力 。 竞 赛 用 的 可 满足 性 问题 有 的 是 随机 生成 的 ， 有 的 是 特意 
构造 出 来 以 提高 难度 的 , 还 有 的 则 是 实际 应 用 中 产生 的 。 这 些 算法 中 有 许多 都 能 解决 
某 些 达 到 一 百 万 个 变量 规模 的 可 满足 性 问题 。 











启发 式 方法 并 不 总 能 奏效 。 没 人 能 在 SAT 竞 赛 中 取得 完美 的 成 绩 。 但 通常 来 讲 ， 
对 各 种 计算 技巧 的 巧妙 使 用 ,再 加 上 当今 最 快 的 机 器 的 强劲 火力 支援 ， 有 些 算法 甚至 
能 求解 规模 很 大 的 最 优化 问题 。 











6.3 ”搜索 小 规模 的 解 








如 果 我 们 想 在 敌 友 国 的 2 万 居民 中 寻找 数目 为 3 的 团 ， 最 原始 的 方法 需要 检查 1 万 
亿 多 一 点 种 可 能 ， 这 对 如 今 的 计算 机 不 太 困 难 。 但 是 数目 增长 得 太 快 了 : 4 个 人 的 团 
就 存在 6000 万 亿 种 可 能 ; 5 个 人 的 团 则 有 26 亿 亿 种 可 能 ; 6 个 人 的 团 则 有 880 万 亿 亿 (88 
后 面 有 21 个 0 ) 种 可 能 。 很 快 ， 问 题 的 规模 就 超出 了 机 器 的 处 理 能 力 。 


























对 于 其 他 NP 完全 问题 , 搜索 小 规模 的 解 可 能 会 简单 一 些 。 如 果 敌 友 国 有 一 群 人 满 
足 如 下 条 件 : 即 对 任意 一 对 朋友 ， 都 至 少 有 一 个 人 在 这 群 人 中 , 那么 这 样 一 群 人 被 称 
为 一 个 舒适 组 (very cozy group )。 








图 6-8 ”舒适 组 





D SAT 为 可 满足 性 问题 ( satisfiability ) 的 前 三 个 字母 。 一 一 译 者 注 
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在 这 个 好 友 关 系 图 中 ，Bob、Danielle 、Frank 和 Harry 组 成 了 一 个 非常 舒适 的 组 ， 
因为 每 对 好 友 关 系 中 至 少 有 Bob 、Danielle 、Frank 和 Harry 中 的 一 个 人 。 





图 6-9 包含 4 个 人 的 舒适 组 


在 这 个 好 友 关 系 图 中 ,不 存在 3 个 人 的 舒适 组 。 例 如 ， 如 果 我 们 把 Alice 、Charlie 和 
Frank 这 3 个 人 看 做 舒适 组 , 那么 就 漏 掉 了 Eve 和 Danielle, 以 及 George 和 Harry 这 两 对 朋友 。 





图 6-10 包含 3 个 人 的 舒适 组 


舒适 组 问题 , 即 人 们 熟知 的 “顶点 覆盖 问题 ”, 是 卡 普 原 来 列 出 的 NP 完全 问题 之 一 。 
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我 们 来 看 图 中 的 Frank。 如 果 Frank 不 在 舒适 组 中 ,那么 George、Danielle 和 Eve 必 
须 在 舒适 组 中 ,因为 他 们 都 和 Frank 是 朋友 关系 。 如 果 Frank 有 100 个 朋友 , 则 要 么 他 自 
己 在 舒适 组 中 ， 要 么 他 所 有 的 朋友 都 在 舒适 组 中 。 


























使 用 这 样 的 技巧 ， 计 算 机 科学 家 可 以 不 用 穷 举 就 能 找到 小 的 舒适 组 。 找 到 5 个 人 的 
舒适 组 只 需要 检查 大 概 100 000 种 可 能 。 找 10 个 人 的 组 则 需 检 查 200 000 种 可 能 。30 个 人 
的 组 则 是 601 000 种 一 一 所 有 这 些 用 你 的 笔记 本 电脑 来 算 基 本 上 瞬间 就 能 完成 。 搜 索 包 
含 113 人 的 舒适 组 需要 检查 1 万 亿 种 可 能 ， 其 计算 时 间 基 本 等 于 搜索 3 个 人 的 团 的 时 间 。 

















等 一 下 ! 卡 普 不 是 证 明 找到 最 小 的 舒适 组 也 是 NP 完 全 问题 吗 ? 看 起 来 寻找 舒适 组 
并 不 怎么 困难 嘛 。 想 想 敌 友 国有 多 少 对 好 友 关 系 。 这 么 多 的 好 友 关 系 ， 舒适 组 根本 不 
可 能 只 用 区 区 113 人 就 保证 每 对 好 友 中 至 少 有 一 个 人 在 其 中 。 当 舒适 组 的 人 数 达 到 合 
理 的 规模 以 后 ， 相 应 的 必须 检验 的 可 能 性 的 规模 会 变 得 非常 大 。 






































如 果 你 寻找 的 是 150 人 的 组 ， 有 1500 万 亿 种 可 能 需要 搜索 ; 200 个 人 则 是 10 万 亿 亿 
种 C10? ); 而 300 人 ， 则 大 概 是 38 后 面 跟 51 个 0。 找 到 敌 友 国 中 最 小 的 舒适 组 基本 上 是 
不 可 能 完成 的 任务 。 但 如 果 我 们 只 是 在 100 个 人 中 寻找 有 没有 舒适 组 ， 这 个 任务 还 是 
可 以 在 合理 的 时 间 内 完成 的 。 























64 近似 计算 方法 





也 许 我 们 没有 问题 的 最 佳 答案 ， 但 通常 一 个 不 坏 的 答案 就 足够 好 了 。 





比如 NP 完全 的 旅行 推销 员 问 题 ， 即 找到 访问 多 个 城市 的 最 短路 线 。 











如 果 我 想到 50 个 城市 旅行 ,最短 的 路 线 是 180 万 英里 ， 而 我 已 经 找到 了 一 个 需要 
181 万 英里 的 路 线 ， 通 常 大 可 不 必 为 多 走 的 1 万 英里 劳 心 费 神 。 


换 一 个 角度 讲 ， 如 果 走 1 英里 要 花费 1 美元 ， 而 我 旅行 的 收入 是 180.5 万 美元 , 那么 
180 万 英里 和 181 万 英里 的 差别 ， 可 能 就 是 挣 5000 美 元 和 赔 5000 美 元 的 差别 。 如 果 我 对 









































虽然 地 图 上 的 旅行 推销 员 问 题 是 一 个 被 认为 难以 有 效 解决 的 NP 完全 问题 ,但 是 我 
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们 可 以 找到 非常 接近 最 优 解 的 旅行 路 线 。 桑 吉 弗 ， 阿 罗 拉 和 乔 ， 米 切 尔 给 出 了 一 个 算 
法 ,原理 是 先 将 地 图 切 分 为 许多 小 块 ， 然 后 在 所 有 小 块 中 找到 小 段 的 最 佳 路 线 ， 最 后 
通过 一 种 高 明 的 方式 将 这 些小 段 的 路 线 连 接 起 来 。 


如 下 图 中 的 71 009 个 中 国 城市 。 








图 6-11 中国 城 市 








我 们 把 一 个 细密 的 网 格 套 在 地 图 上 ， 然 后 在 每 个 小 格 中 求解 旅行 推销 员 问 题 。 如 
果 茶 个 小 区 域 的 城市 太 多 ， 那 就 进一步 把 该 区 域 细 分 成 更 小 的 网 格 。 











用 这 种 技术 ， 我 们 可 以 在 合理 的 时 间 内 ， 找 到 与 最 优 方 案 只 差 百 分 之 几 的 方案 。 





































































































































































































































































































































































































图 6-12 中国 城市 的 网 格 
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如 果 所 有 NP 问题 都 有 这 么 好 的 近似 计算 方法 ， 那 么 P/NP 问 题 几 乎 就 不 重要 了 。 
然而 生活 没有 那么 轻松 。 比 如 团 问题 ， 即 找到 一 大 群 互 为 朋友 的 人 。 目 前 还 不 存在 任 
何 通 用 的 方法 可 以 估算 最 大 团 的 问题 。 敌 友 国 可 能 存在 2000 人 的 团 , 但 在 合理 的 时 间 
内 ,我们 连 15 人 的 团 都 找 不 到 。 





如 果 P= NP , 我 们 就 能 有 效 地 找到 全 局 最 大 团 。 这 被 证 明 是 能 稳定 地 找到 团 的 
方式 ,哪怕 是 寻找 人 数 是 最 大 团 的 0.1% 的 团 ,也 只 能 采取 这 种 方式 。 发 现任 何 
能 比 这 更 好 地 通过 估算 来 解决 团 问题 的 算法 ,都 将 令 P= NP ， 即 有 效 地 解决 团 问 是 
本 身 。 





IJ 
































许多 NP 问题 既 不 像 团 问 题 这 样 难以 估算 ,又 不 像 地 图 上 的 旅行 推销 员 问 题 那样 容 
易 估 算 。 让 我 们 回 过 头 再 来 看 看 舒适 组 问题 。 


像 这 样 一 个 小 规模 的 例子 ， 我 们 通过 穷 举 就 能 得 出 最 小 的 舒适 组 有 4 个 人 ， 例 如 


Frank 、Danielle 、Harry 和 Bob。 假 设 我 们 不 知道 这 一 点 ， 让 我 来 描述 一 个 估算 最 小 舍 
适 组 的 简单 的 算法 。 








图 6-13  $fX&7HII 


首先 任 选 一 对 朋友 ， 比 如 Alice 和 Harry， 并 标记 他 们 。 
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图 6-14 PEHI, 2A dp iU 
找到 另 一 对 没 被 标记 的 朋友 ， 然 后 也 标记 他 们 。 





图 6-15 PEHI, LAWER 
重复 上 一 过 程 直 到 找 不 到 未 被 标记 的 朋友 。 


最 后 ， 所 有 被 标记 的 人 组 成 的 将 是 一 个 舒适 组 。 


在 这 个 示例 中 ， 我 们 得 到 了 一 个 6 人 的 舒适 组 。 每 个 舒适 组 都 要 从 被 标记 的 3 组 好 友 
中 每 组 至 少 选 一 个 人 ,所 以 人 数 不 能 少 于 3 人 。 那 么 最 好 的 舒适 组 的 人 数 应 该 在 3 到 6 之 间 。 
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图 6-16 ”舒适 组 工 ，6 人 被 标记 


这 个 算法 适用 于 所 有 的 好 友 关 系 图 。 如 果 我 们 的 算法 找到 了 人 数 为 100 的 舒适 组 
( 即 总 共 添 加 了 50 对 好 友 )， 那 么 我 们 知道 最 好 的 舒适 组 应 该 在 50 到 100 人 之 间 。 


我 们 总 能 找到 一 个 舒适 组 ， 它 的 人 数 是 最 小 和 舒适 组 人 数 的 2 倍 。 我 们 能 得 到 比 这 
好 很 多 的 结果 吗 ? 也 许 不 能 。 





如 果 P= NP ， 我 们 就 能 轻松 找 出 最 小 的 舒适 组 。 但 如 果 P=#NP 呢 ? 一 般 地 讲 ， 
不 可 能 找到 比 最 小 人 数 多 36% 或 更 小 的 舒适 组 。 任 何 能 找到 比 最 小 人 数 多 36% 的 舒适 
组 的 算法 , 都 能 被 转化 为 一 个 可 解决 所 有 NP 问 题 的 算法 。 这 个 转化 的 过 程 与 一 系列 在 
1990 年 到 2005 年 之 间 证 明 的 艰 次 结论 有 关 。 

上 面 介绍 的 简单 算法 通过 逐个 添加 一 对 好 友 ， 能 找到 最 多 两 倍 于 最 小 人 数 (也 就 
是 比 最 小 人 数 多 100% ) 的 舒适 组 。 如 果 P# NP ， 那 么 我 们 能 希望 的 最 好 结果 就 是 找 
到 比 最 小 人 数 多 36% 的 舒适 组 。 我 们 有 可 能 找到 比 最 小 人 数 多 50% 的 舒适 组 吗 ? 











为 解答 上 述 问 题 和 其 他 相关 问题 ， 计 算 机 科学 家 萨 布 哈 什 ， 替 特 引入 了 一 种 他 称 
为 独特 游戏 (unique games ) 的 问题 ， 该 问题 是 地 图 填 色 问题 的 一 个 变种 ， 增 加 了 一 
些 约束 相 邻 地 区 填 色 方式 的 规则 。 独特 游戏 猜想 是 说 独特 游戏 是 NP 完 全 的 , 人 们 至 今 
无 法 判断 该 猜想 是 否 为 真 "。 




















D 关于 独特 游戏 和 独特 游戏 猜想 ， 参 见 维基 百科 页 面 http://en.wikipedia.org/wiki/Unique_games_conjecture。 
一 一 译 者 注 
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如 果 独 特 游戏 猜想 是 真 的 , 我 们 甚至 可 以 进一步 约束 近似 计算 的 能 力 。 霍 特 证 明 ， 
如 果 该 猜想 为 真 ， 那 么 不 能 找到 比 最 小 人 数 的 2 倍 只 少 一 点 的 舒适 组 。 如 果 该 猜想 为 
真 ， 我 们 不 能 得 到 比 上 述 简单 算法 好 很 多 的 结果 。 











6.5 ”解决 一 个 不 同 的 问题 


有 时 候 不 论 多 么 高 明 的 技巧 ,都 对 某 个 NP 问题 无 能 为 力 。 那么 , 我 们 可 以 试 着 解 
决 男 一 个 不 同 的 问题 。 











简 是 帕 罗 奥 图 市 一 家 名 为 图 灵 之 家 ( Chez Turing ) 的 餐馆 的 主 厨 ， 她 想 研 发 一 种 
新 的 番茄 沦 来 搭配 她 的 名 菜 一 一 砂锅 意 面 。 图 灵 之 家 是 一 家 引领 风潮 的 新 派 饭 店 ， 它 
开创 了 计算 派 菜系 。 简 不 直接 使 用 食物 做 试验 ， 而 是 向 计算 机 输入 她 想 要 的 颜色 、 味 
道 、 气 味 和 口感 ， 然 后 计算 机 就 会 搜索 各 种 食材 的 组 合 ， 精 确 调配 出 所 需 的 口味 ， 这 
样 研发 的 新 菜 不 仅 好 吃 ， 并且 降低 了 制作 成 本 和 所 含 的 热量 。 这 一 次 ， 简 想 要 研发 一 
种 深 红 色 的 酱 ， 辛 藻 等 级 为 5， 口 感 类 似 燕麦 但 更 顺 滑 ， 能 轻 触 味 蔓 5 和 11， 并 能 对 砂 
锅 意 面 本 身 的 味道 产生 其 他 各 种 微妙 的 影响 ， 以 达到 完美 的 进食 体验 。 



























































计算 机 没 能 找到 符合 她 所 有 要 求 的 食材 组 合 方式 。 于 是 简 打 电话 给 计算 机 天 才 汤 
姆 ,他 答应 过 来 帮助 简 ， 顺 市 赚 取 一 顿 免费 大 餐 。 汤 姆 尝试 了 他 知道 的 所 有 启发 式 方 
法 ， 也 用 了 他 查 到 的 儿 种 新 方法 。 他 还 到 云端 ， 租 借 了 Amazon 机 器 上 的 计算 时 间 ， 
试图 用 真正 生猛 的 计算 能 力 来 攻破 问题 。 而 那 也 没有 奏效 。 他 接着 去 拜访 湾 区 的 所 有 
朋友 ,并 宣布 为 第 一 个 找到 制作 桨 料 方法 的 人 提供 一 个 令 人 垂 省 的 图 灵 之 家 的 预定 餐 
位 。 一 周 后 ， 所 有 人 都 表示 放弃 ， 因 为 这 个 问题 实在 太 难 解决 了 。 


汤姆 回去 告诉 简 这 个 坏 消息 。 这 是 他 第 一 次 没 能 找到 简 需 要 的 食材 和 制作 方式 。 
汤姆 问 :“ 能 不 能 试 试 用 其 他 方式 来 做 酱 料 ， 比 如 稍微 改变 一 下 味道 ? ” 简 不 肯 让 步 ， 
认为 酱 料 必须 要 具备 这 种 味道 和 口感 , 否则 会 破坏 砂锅 意 面 在 口中 的 感觉 。 汤 姆 又 问 : 
“ 那 砂 锅 意 面 本 身 呢 ? ” 



























































既然 为 这 种 特定 的 砂锅 意 面 找到 合适 的 桨 汁 是 一 个 很 难 的 计算 问题 ， 简 和 汤姆 转 而 
搜索 新 的 能 够 完美 契合 的 砂锅 意 面 和 酱 汁 。 这 个 任务 稍微 容易 计算 一 些 ， 计 算 机 在 数 小 
时 内 就 输出 了 一 份 食物 配方 。 通过 改变 要 解决 的 问题 , 图 灵 之 家 又 有 了 一 道 新 的 招牌 荣 。 
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在 另 一 种 情境 中 , 改变 要 解决 的 问题 则 令 计算 机 安全 专家 们 头痛 不 已 ， 他 们 开发 
出 的 最 新 加 密 技 术 能 让 交易 变 得 更 加 安全 ,前 提 是 坏蛋 只 用 专家 们 预想 到 的 方法 来 破 
译 密码 。 但 是 坏蛋 们 往往 不 按 套 路 出 牌 ， 却 偶尔 能 至 打 正 着 。 












































智能 卡 表面 上 和 信用 卡 一 样 , 但 里 面 内 树 了 一 个 小 小 的 处 理 带 , 存储 着 一 个 密 钥 。 
智能 卡 可 以 用 来 识别 身份 ， 也 能 存 少 量 的 钱 ， 这 样 你 在 商店 购物 或 者 泊 车 咪 表 处 交 费 
时 ， 就 不 用 和 集约 化 的 计算 机 进行 连接 和 通信 也 能 完成 交易 。 即 使 有 人 能 截取 到 智能 
卡 的 输出 和 输入 数据 流 ， 也 很 难 猜 出 密 钥 。 


























假如 托马斯 在 酒店 工作 ， 趁 安妮 去 游泳 的 时 候 拿 了 她 的 智能 卡 。 托 马 斯 有 一 个 
特殊 的 读 卡 锅 ， 用 它 能 试 着 给 智能 卡 发 送 一 些 数据 ， 然 后 看 看 返回 了 些 什 么 数据 。 
如 果 P= NP , 那么 窃贼 能 根据 这 些 输入 /输出 行为 找到 密 钥 。 而 我 们 更 有 可 能 生活 在 
Pz NP 的 世界 里 ， 找 到 密 钥 是 很 困难 的 。 智 能 卡 数据 交换 协议 是 经 过 精心 设计 的 ， 
本 章 提 到 的 蛮 力 搜索 或 启发 式 算法 等 技术 对 于 找到 密 钥 都 收效 甚 微 。 如 果 找 不 到 密 
钥 ， 托 马 斯 通常 只 能 把 卡 还 给 安妮 ， 或 者 当 安 妮 发 现 卡片 丢失 ， 直 接 给 银行 打 电 话 
注销 这 张 卡 。 












































而 托马斯 不 是 一 般 的 身份 窃贼 。 他 能 以 设计 者 意 想 不 到 的 方式 来 “使 用 ” 智 
卡 。 他 把 卡 扔 到 微波 炉 里 加 热 几 秒 。 你 可 别 在 家 尝试 这 个 ,微波炉 的 能 量 会 让 智 
卡 或 任何 其 他 电子 设备 接近 报废 。 即 使 是 很 得 时 间 的 微波 加 热处理 ， 也 可 能 导致 某 
些 电 路 的 短路 ， 即 使 不 是 永久 性 地 损伤 智能 卡 ， 也 会 让 它 的 输入 /输出 行为 变 得 无 
法 预料 。 


























无 法 预料 的 行为 正 是 托马斯 想 要 的 。 如 果 智 能 卡 正常 工作 ,他 也 许 不 知道 如 何 找 
到 密 钥 。 而 一 个 略微 受 损 的 智能 卡 虽 然 仍 可 以 对 输入 的 数据 做 出 响应 , 但 是 输入 /输出 
的 行为 也 和 原来 不 一 样 了 。 








新 的 输入 /输出 行为 仍 与 密 钥 有 关 ， 但 是 原来 那 种 令 密 钥 难以 被 找到 的 设计 失效 
了 。 这 时 如 果 托 马 斯 再 使 用 启发 式 或 蛮 力 搜索 等 方法 来 寻找 密 钥 ， 就 有 可 能 奏效 。 






































一 旦 托马斯 找到 密 钥 , 他 就 能 用 它 制 作 两 个 和 安妮 原先 正常 的 卡片 一 模 一 样 的 知 
能 卡 。 托 马 斯 把 其 中 之 一 还 给 安妮 ， 另 一 个 留 给 自己 。 托 马 斯 如 果 足 够 小 心 的 话 ， 就 
可 以 从 安妮 的 账户 偷 钱 ， 而 安妮 和 银行 可 能 要 等 几 周 或 几 个 月 后 才 会 发 现 问题 。 
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托马斯 找到 密 钥 的 方式 是 ,把 一 个 被 故意 设计 成 难以 解决 的 NP 问题 转变 为 一 个 完 
全 没 被 设计 过 的 问题 。 新 一 代 的 智能 卡 已 经 拥有 了 对 抗 微波 攻击 的 机 制 。 但 我 们 绝 不 
能 低估 那些 一 心 想 找 到 秘密 信息 的 家 伙 们 的 想象 力 。 














6.6 接受 现实 


有 时 候 一 个 问题 天 生 排 斥 任何 可 能 解决 它 的 方法 ， 对 此 你 能 做 的 只 有 放弃 ， 然 后 
去 干 点 别 的 。 





理 查 德 偶 然 发 现 了 一 种 超级 药物 的 化 学 式 , 这 种 药 能 让 他 主 罕 世界 , 或 者 至 少 是 
主 备 大 辛辛那提 区 。 他 制定 了 一 个 向 米 勒 市 水 处 理 三 投放 药物 的 计划 , 喝 了 水 的 居民 
将 失去 警惕 ， 变 得 非常 容易 被 操控 。 到 那 时 ， 理 查 德 就 能 “挺身 而 出 ” ， 接 管 他 们 的 
社会 。 














只 要 收集 到 足够 多 的 合适 的 化 学 品 ， 理 查 德 就 能 实现 他 的 梦想 。 不 幸 的 是 ， 以 前 
发 生 的 某 次 事件 导致 政府 禁止 了 供应 商 直 接 向 任何 个 人 出 售 这 些 化 学 品 。 于 是 理 查 德 
开始 分 析 如 何 分 解 各 种 日 用 品 ， 然 后 从 原料 中 制备 这 些 化 学 品 。 理 查 德 往 笔记 本 电脑 
里 输入 了 各 种 参数 : 购买 日 用 品 的 成 本 ， 从 大 辛辛那提 区 的 20 个 沃尔玛 和 14 个 Targets 
超市 能 够 安全 购买 而 不 引起 怀疑 的 每 种 日 用 品 的 数量 ,运输 和 仓储 的 成 本 ( 他 需要 好 
几 个 仓库 来 放 买 来 的 东西 )。 有 好 多 种 日 用 品 的 组 合 可 供 选 择 。 他 把 这 些 参数 输入 电 
脑 , 但 是 需要 检查 的 可 能 性 数量 太 多 了 ,计算 机 无 法 找到 符合 他 的 时 间 和 资金 限制 的 
方案 。 他 打 心 眼 里 觉得 一 定 存在 满足 所 有 条 件 的 方案 ， 但 不 管 他 怎么 尝试 ,用 尽 了 所 
有 他 从 网 上 能 找到 的 启发 式 方法 和 估计 算法 ,就 是 找 不 到 这 样 一 个 能 凑 齐 所 需 化 学 品 
的 方案 。 最 终 理 查 德 放弃 了 ， 回 到 他 在 本 地 牙膏 厂 的 保安 岗位 上 。 
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就 这 样 ，NP 问 题 的 复杂 性 拯救 了 辛辛那提 。 











通常 , 只 一 种 技术 不 足以 处 理 人 们 面临 的 困难 的 NP 问题 。 我 们 经 常 需要 尝试 本 章 
提 到 的 几 种 技术 。 如 果 无 法 解决 需要 解决 的 问题 , 那么 可 以 尝试 解决 一 个 不 同 的 问题 。 
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如 果 新 的 问题 仍然 是 NP 完 全 问题 ， 那 我 们 还 可 以 用 某 些 启发 式 方法 来 对 它 发 起 进攻 。 
启发 式 方法 很 少 能 完全 地 解决 问题 ， 但 是 它们 可 以 给 出 足够 好 的 近似 解决 方案 。 








如 果 P= NP , 所 有 这 些 问题 都 将 烟消云散 , 我 们 将 用 一 个 简单 的 算法 做 很 多 不 
简单 的 事情 。 但 即使 事实 如 我 们 料想 的 那样 C BI P e NP )， 我 们 还 是 几乎 总 能 收获 
点 什么 。 可 能 过 程 中 需要 付出 更 多 的 努力 ,可 能 最 终 解决 的 问题 和 最 想 解决 的 问题 
不 大 一样 , 可 能 根本 无 法 得 到 最 好 的 解决 方案 。 但 是 , 如 果 我 们 仍然 能 把 事情 做 完 ， 
那 就 足够 好 了 。 
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证 明 P - NP 

















尤 里 斯 : 哈 特 马 尼 斯 是 计算 复杂 度 理论 的 芮 基 人 之 一 ， 他 曾 说 :“ 我 们 都 知道 P 和 
NP 不 一 样 ， 但 就 是 不 知道 如 何 证 明 这 一 点 。” 





























我 们 在 前 面 几 章 中 从 多 方面 探讨 了 P/NP 问 题 ， 包 括 它 是 什么 ， 它 的 研究 意义 ， 
P = NP 的 虚幻 美妙 世界 ， 以 及 如 何 处 理由 Pz NP 带 来 的 困难 问题 。 























P/NP 问 题 也 是 一 个 迷人 而 富有 挑战 性 的 数学 问题 。 从 库 克 、 卡 普 和 莱 文 将 这 个 问 
题 及 其 重要 意义 呈现 给 世界 的 那 一 刻 起 , 计算 机 科学 家 和 数学 家 就 一 直 和 努力 形式 化 地 
证 明 P= NP 或 P# NP 。 但 所 有 常规 的 手段 都 失效 了 。 到 20 世 纪 70 年 代 未 ， 大 家 达成 
的 共识 是 “PNP 问 题 的 解决 可 能 有 赖 于 大 幅度 创新 的 证 明 技术 ”。 
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辑 上 说 得 通 吗 ? $ 


你 好 ， 我 是 一 名 反 逻 辑 
学 的 科学 家 。 我 能 证 明 
你 正在 写 的 那个 软件 不 
可 能 正常 工作 。 
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图 7-1 DILBERT © 1997 Scott Adams。 使 用 需 得 到 UNIVERSALUCLICK 
的 许可 ， 版 权 所 有 ， 侵 权 必 究 
接 下 来 的 几 十 年 中 ， 计 算 机 科学 和 数学 都 取得 了 不 可 思议 的 进步 ， 包 括 解 决 了 所 
有 未 解决 数学 问题 中 最 著名 的 一 个 一 一 费 马 大 定理 。1637 年 左右 ， 法 国 律师 兼 数学 爱 
好 者 皮 埃 尔 ' 德 ， 费 马 在 他 的 《算术 》( 一 本 古 和 希腊 教科 书 ) 的 书页 边缘 上 写 下 如 下 
这 样 一 段 文字 : 




















95738 证 明 P 关 NP | 95 


将 一 个 立方 数 分 成 两 个 立方 数 之 和 ， 或 一 个 四 次 晨 分 成 两 个 四 次 震 之 
和 ， 或 更 一 般 地 ， 将 一 个 高 于 二 次 的 霸 分 成 两 个 同 次 霸 之 和 ， 都 是 不 可 能 
的 。 对 此 我 确信 已 发 现 了 一 种 美妙 的 证 明 方法 ,可惜 这 里 空白 的 地 方太 小 ， 
写 不 下 。 

















也 就 是 说 ， 不 存在 大 于 0 的 三 个 自然 数 g、5 和 c， 以 及 大 于 2 的 自然 数 上 ， 能 令 
a"+b"=c”。 费 马 再 也 没有 提 到 这 个 定理 的 证 明 方法 ， 也 有 可 能 他 压根 就 没 想 出 正确 的 
证 法 。 后 来 这 个 问题 闻名 于 世 ， 成 为 一 个 经 典 的 数学 未 解 之 迹 。 我 小 时 候 也 梦想 成 为 
第 一 个 解决 这 个 著名 问题 的 人 。 另 外 一 个 和 我 有 着 共同 梦想 的 小 孩 长 大 后 实现 了 他 的 
梦想 。1994 年 ， 普 林 斯 顿 大 学 的 数学 家 安德鲁 怀 尔 斯 在 前 人 发 表 的 一 系列 有 关 数 论 
的 论文 基础 上 ,构造 出 了 费 马 定理 的 证 明 。 他 立刻 成 了 名 人 ,至 少 拥有 了 作为 一 个 数 
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这 一 童 不 会 告诉 你 如 何 解 决 P/NP 问 题 , 否则 这 将 是 一 本 非常 不 同 的 书 。 我 们 只 会 
介绍 一 些 人 们 在 尝试 解决 P/NP 问 题 时 曾经 产生 过 的 想法 。 可 惜 , 这些 想法 没 能 让 我 们 
距离 解决 该 问题 更 近 一 点 。 要 证 明 Pz NP ， 就 要 证 明 不 存在 能 解决 某 些 NP 问 题 的 算 
法 〈 甚 至 包括 那些 未 被 发 现 的 算法 )。 很 难 去 证 明 不 可 能 做 成 某 件 事 ， 尽 管 这 在 逻辑 
上 并 非 不 可 能 。 所 以 ， 对 于 这 个 也 许 是 所 有 数学 问题 中 最 为 重要 同时 最 具 挑 战 性 的 问 
题 ， 我 们 还 是 希望 看 到 它 被 解决 的 那 一 天 。 











7.1 WTE 


请 考虑 如 下 这 个 令 人 困惑 的 命题 。 





This sentence is not true. 














图 7-2 方 框 中 的 命题 ， 这 个 命题 不 是 真 的 





















































这 个 命题 是 真是 假 ? 如 果 它 是 假 的 ,那么 它 不 能 不 是 真 的 ， 双 重 和 否定 意味 着 它 是 



































良好 的 数学 系统 中 是 不 允许 出 现 正确 的 悖 论 的 ， 悖 论 的 存在 说 明 数 学 系统 不 够 好 。 
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“这 个 命题 不 是 真 的 ”是 不 可 被 数学 规范 化 的 ， 因 为 一 个 命题 不 能 讨论 它 本 身 的 真 伪 。 


4 


20 世 纪 30 年 代 ， 库 尔 特 ， 哥 德尔 发 现 了 数学 可 以 讨论 证 明 的 真 伪 ， 他 可 以 构造 一 些 
数学 命题 ， 来 表明 其 他 的 命题 是 否 存在 能 证 明 其 正确 性 的 证 据 。 哥 德尔 发 现 了 如 何 让 一 
个 命题 讨论 它 本 身 正确 性 的 证 明 是 否 存在 的 方法 ,并 建立 了 一 个 与 上 面 类 似 的 数学 公式 : 


There is no proof that this sentence is true. 


图 7-3 方 框 中 的 证 据 : 没有 证 据 表明 这 个 命题 是 真 的 





























假设 这 个 命题 为 假 ， 那 么 有 证 据 表 明 这 个 命题 是 真 的 ， 这 和 它 为 假 的 假设 矛盾 ， 
所 以 这 个 命题 必须 是 真 的 。 



































我 们 又 遇 到 悖 论 了 吗 ? 不 完全 是 。 这 个 命题 是 真 的 , 然而 没有 证 据 表明 它 是 真 的 。 
哥 德 尔 看 似 轻 描 淡 写 的 一 击 ， 却 撼动 了 数学 大 厦 的 基础 : 存在 人 们 不 能 证 明 其 为 真 的 
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如 果 有 人 告诉 你 他 有 一 个 能 预测 未 来 的 魔 盒 。 你 就 问 他 你 会 用 右手 打 他 还 是 用 左 
手 。 如 果 盒 子 说 左手 ， 你 就 用 右手 打 那 个 人 。 如 有 果 盒 子 说 右手 ， 你 就 用 左手 。 不 管 怎 
样 盒子 都 是 错 的 。 


计算 也 同样 可 以 这 样 。 我 们 都 见 过 计算 机 屏幕 上 出 现 一 个 代表 忙碌 的 小 沙漏 ,不 
知道 这 是 代表 计算 机 死机 了 ， 还 是 在 进行 长 时 间 的 计算 。 用 户 该 马上 重启 机 带 呢 ， 还 
是 再 等 一 会 儿 ? 如 果 能 有 一 个 算法 , 告诉 我 们 计算 机 是 不 是 陷 进 了 某 种 无 穷 循 环 该 多 
好 ! 那 是 很 好 ,但 那 也 是 不 可 能 的 。 



















































































为 理解 其 中 的 道理 ,我 们 先 来 看 一 下 1936 年 阿兰 . 图 灵 在 开创 计算 机 科学 的 论文 
中 给 出 的 一 个 例子 。 计 算 机 程序 也 是 数据 ， 就 像 文 档 和 报表 一 样 。 程 序 可 以 分 析 程 序 
的 代码 。 


一 个 计算 机 程序 要 么 最 终结 束 计算 并 输出 结果 ， 要么 永远 算 下 去 。 假 设 我 们 有 一 
个 算法 , 它 能 告诉 我 们 某 个 程序 是 否 会 最 终结 束 。 我 们 把 这 个 程序 对 它 本 身 运行 一 下 。 

































































都 确实 是 真 的 。 于 是 哥 德 尔 同时 也 表明 了 , 我们 不 能 证 明 “ 所 有 能 被 证 明 为 真 的 命题 都 确实 是 真 的 ”， 
除非 我 们 能 证 明 假 的 命题 。 这 就 是 你 读 脚注 的 好 处 。 











CD 我 们 刚才 没有 证 明 那 个 命题 是 真 的 吗 ? 不 完全 如 此 ， 因 为 不 得 不 首先 假设 所 有 能 被 证 明 为 真 的 命题 





第 7 章  WEBJPzNP | 97 





If the program inside this box finishes then run forever. 


























图 7-4 ” 方 框 中 的 程序 ， 如 果 这 个 方 框 中 的 程序 结束 ， 那 么 它 会 永远 运行 下 去 








这 个 方 框 中 的 程序 要 么 会 结束 ， 要 么 不 会 结束 。 不 管 怎 样 ， 我 们 都 遇 到 了 了 矛盾 。 
所 以 我 们 的 假设 是 错误 的 ， 即 不 存在 一 个 程序 ， 能 告诉 我 们 某 个 程序 能 否 最 终结 
PC 上 没有 ，Mac 上 也 没有 。 现 在 没有 ，100 年 后 也 不 会 有 。 不 存在 一 个 程序 能 告诉 我 
们 某 个 程序 能 否 最 终结 束 ， 就 这 么 简单 。 




















我 们 能 用 类 似 的 思路 来 证 明 人 们 无 法 高 效 地 解决 某 些 问题 , 也 就 是 证 明 该 问题 不 
属于 类 型 P〈 即 我 们 能 高 效 解 决 的 问题 ) 吗 ? 这 确实 是 可 行 的 。 











我 们 先 构造 一 个 算法 Q, 将 一 段 程 序 R 的 代码 作为 其 输入 数据 , 它 的 工作 原理 如 下 : 




















口 如 果 程 序 R 在 使 用 R 的 代码 作为 数据 时 能 很 快 输出 “Yes”， 那 么 Q 输 出 “No”; 
口 否则 Q 输 出 “Yes”。 














假设 算法 S 是 一 个 高 效 的 算法 。 那 么 ，Q(S) 当 且 仅 当 S(S) 输 出 “No” 的 时 候 输 出 
“Yes”。 所 以 不 存在 行为 与 Q 完 全 相同 的 高 效 算法 。 





























Q 仍 然 是 一 个 符合 规范 的 算法 。 所 以 Q 所 解决 的 这 个 问题 是 可 被 计算 的 ,但 不 能 
被 高 效 地 计算 。 








如 果 我 们 能 证 明 Q 在 NP 中 ， 也 就 是 说 ， 可 以 高 效 地 验证 其 解 的 有 效 性 ， 那 么 Q 在 
NP 中 ， 而 不 在 P 中 。 这 意味 着 PNP ， 从 而 解决 了 那个 伟大 的 问题 。 












































但 是 我 们 不 知道 ， 而 且 通 常 不 认为 ， 存 在 一 个 关于 Q 的 NP 算法 。 由 于 这 个 原因 以 
及 其 他 的 某 些 原 因 ， 这 条 试图 以 悖 论 来 解决 P/NP 问 题 的 道路 注定 会 通 向 失败 ， 至少 它 
不 能 直接 用 来 证 明 P z NP 。 




















7.2 电路 


现代 计算 设备 的 核心 都 有 一 块 集成 电路 板 。 























集成 电路 由 上 百 万 或 上 百 亿 个 微小 的 晶体 管 组 成 。 晶体 管 是 一 种 能 放大 并 控制 
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子 脉冲 的 元 件 , 它们 实现 了 逻辑 门 ( gate )， 即 一 些 构建 在 带 有 电荷 的 导线 上 的 简单 逻 
辑 操作 。 
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一 一 一 一 一 -一 = 一 


——— 


图 7-5 电路， 图 片 由 宾夕法尼亚 大 学 电子 和 系统 工程 系 提供 








我 们 首先 来 看 简单 的 导线 。 每 根 线 要 么 带 有 高 电压 ， 要 么 带 低 电压 ， 只 能 取 两 个 
值 中 的 一 个 ， 这 经 常 被 表示 为 开 和 关 、1 和 0， 或 是 真 和 假 。 我 们 将 这 些 二 元 系统 称 之 
为 比特 (bit )， 即 “二 元 数字 ”( binary digit) 的 简称 。 





一 根 导 线 做 不 了 什么 ， 儿 根 在 一 起 也 能 力 有 限 。 为 了 构成 计算 能 力 , 我 们 要 对 导线 
上 的 信息 进行 一 些 逻 辑 操作 。 其 中 最 简单 的 就 是 翻转 导线 的 值 ,这 叫做 非 门 ( NOT gate )。 


真 假 假 b» E 








图 7-6 3E] 
如 果 非 门 的 左边 有 电压 ， 那 么 右边 就 没有 ， 反 之 亦 然 。 





计算 的 真正 力量 并 不 是 对 单个 导线 的 操作 ,而 来 自 于 将 多 条 导线 的 值 以 某 种 机 制 
合并 。 与 门 (AND gate) 将 2 条 或 更 多 条 导线 的 值 合并 为 一 个 值 ， 该 值 仅 在 所 有 导线 
的 值 都 为 真 时 为 真 。 或 门 COR gate ) 将 2 条 或 更 多 条 导线 的 值 合并 为 一 个 值 ， 该 值 在 
至 少 有 一 条 导线 的 值 为 真 时 为 真 。 
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假 
假 





图 7-7 与 门 和 或 门 





我 们 能 用 这 些 简 单 模块 构建 更 复杂 的 逻辑 操作 。 比 如 ， 两 条 导线 做 异 或 操作 
( Exclusive-OR ) 的 值 只 在 仅 有 一 条 导线 的 值 为 真 时 为 真 。 





图 7-8” 蜡 或 门 


每 一 个 函数 ， 无 论 它 多 复杂 ， 都 能 用 与 、 或 、 非 三 种 门 组 成 的 电路 来 计算 。 让 我 
们 回顾 一 下 敌 友 国 的 团 问题 ， 即 我 们 想 找到 一 群 彼此 互 为 好 友 的 人 。 我 们 可 以 用 一 个 
与 门 来 表示 Alice、Bob 和 Carol 是 否 互 为 朋友 。 


Alice 和 Bob 是 好 友 关 系 吗 ? Alice、Bob 和 Carol 可 以 组 成 一 个 团 吗 

可 以 组 成 一 152 
Bob 和 Carol 是 好 友 关 系 吗 ? > | 
Alice 和 Carol 是 好 友 关 系 吗 ? 


图 7-9 5] 
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假设 我 们 想 知 道 在 Alice 、Bob 、Carol、David 和 El 中 是 否 存 在 3 个 人 的 团 。 我 们 用 
图 7-10 中 的 电路 来 计算 这 个 问题 。 

















这 个 电路 有 10 个 与 门 , 表示 的 是 从 5 人 里 面 找 出 可 能 成 团 的 3 个 人 , 共有 10 种 可 能 。 
假设 我 们 现在 要 从 敌 友 国 的 2 万 人 中 找 出 50 人 的 团 。 直 接 转 换 的 电路 将 有 








3 481 788 616 673 927 174 126 704 329 430 033 822 428 741 136 969 800 292 509 234 
146 086 195 855 824 730 457 281 170 250 134 309 383 506 694 008 809 661 825 431 661 
561 845 957 650 386 210 936 569 600 


个 与 门 ， 规 模 大 到 无 法 实现 。 














图 7-10” 团 问题 的 电路 














这 和 P/NP 问 题 有 什么 关系 呢 ? 每 一 个 ?中 的 问题 C 即 每 一 个 能 被 高 效 地 求解 的 问 
题 )， 都 对 应 一 个 规模 相对 较 小 的 由 与 、 或 、 非 门 构成 的 电路 ， 并 且 该 电路 能 够 求解 
该 问题 。 如 果 我 们 能 证 明 某 些 NP 中 的 问题 (例如 团 问题 )， 不 能 对 应 一 个 小 规模 的 电 
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路 ， 那 么 就 证 明了 NPP 。 





























那 是 否 能 证 明 团 问题 不 能 对 应 小 规模 的 电路 ?这 个 问题 和 P/NP 问 题 密切 相关 , 同 
样 也 是 未 知 的 ， 尽管 大 部 分 计算 机 科学 家 都 相信 团 问题 不 对 应 小 规模 的 电路 ， 正 如 他 
们 相信 Pz NP 一 样 。 























看 看 我 们 上 面 为 团 问题 构造 的 电路 。 注 意 其 中 没有 非 门 。 不 是 所 有 的 问题 都 能 对 
应 不 含 非 门 的 电路 ， 比 如 简单 的 异 或 操作 的 电路 就 必须 包含 非 门 。 然 而 ， 团 问题 就 可 
以 用 只 有 与 门 和 或 门 的 电路 来 计算 ,尽管 这 些 电 路 的 规模 极为 庞大 。 









































1985 年 ， 莫 斯 科斯 捷克 洛 夫 数学 研究 所 的 一 名 学 生 亚 历 山大 拉 兹 波 洛 夫 证 明 ， 
如 果 电 路 只 包含 与 门 和 或 门 《 没 有 非 门 )， 那么 任何 能 求解 团 问题 的 电路 必须 使 用 数 
量 极 多 的 逻辑 门 。 这 并 没有 解决 PINP 问 题 。 因 为 虽然 可 以 在 求解 团 问题 的 电路 中 不 使 
用 非 门 ， 但 说 不 定 使 用 非 门将 显著 降低 电路 所 需 的 逻辑 门 的 数量 。 






































尽管 如 此 , 拉 效 波 洛 夫 的 工作 曾 被 看 成 是 有 望 解决 PNP 问 题 的 突破 性 进展 。 我 的 
博士 生 导 师 迈 克 尔 ' 塞 普 斯 当年 认为 PINP 问 题 的 解决 指日可待 。 需 要 做 的 只 是 对 拉 效 
波 治 夫 的 方法 稍 加 改进 , 让 它 也 适用 于 非 门 。 如 果 成 功 , 那么 作为 NP 问题 之 一 的 团 问 
题 ， 其 求解 电路 必须 要 使 用 数量 极 大 的 与 、 或 、 非 三 种 逻辑 门 。 所 以 团 问题 没有 高 效 
能 的 算法 ， 因 为 所 有 高 效能 的 算法 都 可 转化 为 小 规模 的 电路 。 这 样 一 来 ， 团 问题 属于 
NP 但 不 属于 P， 从 而 证 明 P NP 。 不 幸 的 是 ， 生 活 并 没 那么 简单 。 












































拉 效 波 洛 夫 发 表 的 那些 论文 是 用 俄 文 写 的 。 在 论文 到 达 美 国 后 ， 塞 普 斯 召集 了 几 
个 苏联 学 生 , 大 家 仔细 地 进行 翻译 , 并且 盼 望 着 拉 效 波 洛 夫 的 下 一 篇 论文 能 给 PNP 问 
题 画 上 一 个 圆满 的 句号 。 拉 效 波 洛 夫 后 来 发 表 了 更 多 优秀 的 论文 ,但 其 中 没有 一 篇 是 
给 出 Pz NP 的 证 明 的 。 











在 第 3 章 我 们 介绍 过 敌 友 国 的 配对 问题 ， 即 按 好 友 关 系 为 敌 友 国 的 一 些 居 民 牵 线 
拱桥。 配对 问题 和 团 问 题 一样 ， 也 对 应 只 使 用 与 门 和 或 门 的 电路 。 证 明 团 问题 对 应 需 
要 大 量 与 门 和 或 门 的 电路 所 用 的 方法 ,同样 也 适用 于 配对 问题 。 任 何 只 用 与 门 和 或 门 
解决 配对 问题 的 电路 ， 都 需要 极 大 数量 的 逻辑 门 。 






































和 团 问 题 不 同 ， 我 们 有 解决 配对 问题 的 高 效 算 法 。 所 以 ， 配 对 问题 存在 使 用 与 、 
或 、 非 三 种 逻辑 门 的 小 规模 电路 。 非 门 对 于 求解 配对 问题 不 是 必要 的 ， 但 是 使 用 非 门 











102 | 可 能 与 不 可 能 的 边界 ，P/NP 问 题 趣 史 


会 显著 降低 电路 所 使 用 的 逻辑 门 的 数量 。 看 上 去 十 分 低级 和 简单 的 非 门 ， 竟 然 列 含 着 
巨大 的 力量 。 


这 个 事实 让 那些 企图 利用 拉 效 波 洛 夫 求解 团 问 题 的 方法 来 解决 PNP 问 题 的 尝试 
遭受 了 极 大 的 挫折 。 即 使 证 明了 某 个 问题 在 只 使 用 与 门 和 或 门 时 电路 规模 很 大 ， 也 并 
不 能 保证 在 引入 非 门 后 电路 的 规模 仍然 会 很 大 。 后 来 拉 效 波 洛 夫 的 工作 澄清 了 这 方面 
的 问题 。 他 明确 地 指出 了 他 的 证 明 在 考虑 到 非 门 时 变 得 分 骨 离 析 ， 并 且 无 法 修补 。 




















后 来 ， 拉 兹 波 洛 夫 和 卡 内 基 梅 隆 大 学 的 史 蒂 文 和 鲁 迪 赫 引 入 了 “自然 证 明 ” 
(natural proof) 的 概念 。 自 然 证 明 涵盖 了 电路 的 各 种 证 明 方 法 中 的 很 大 一 部 分 ， 并 给 
出 了 很 强 的 证 据 表明 不 可 能 用 这 些 方法 解决 P/NP 问 题 。 





























同时 , 使 用 非 “自然 ” 的 、 基 于 本 章 前 面 提 到 的 悖 论 思 想 的 方法 来 构造 电路 的 尝 
试 , 也 取得 了 一 些小 小 的 进展 。 然而 试图 通过 “证 明 某 个 NP 问题 需要 大 规模 的 求解 电 
路 ”的 方法 来 找到 P/NP 问 题 的 答案 ， 可 能 性 已 经 变 得 微乎其微 。 














7.3 ”证 明 P 关 NP 时 和 党 犯 的 错误 





2010 年 8 月 6 日 ， 惠 普 实验 室 的 科学 家 维 纳 里 ， 德 奥 拉 利 卡 向 22 位 顶尖 的 理论 计算 
机 科学 家 发 送 了 他 写 的 论文 , 题目 简洁 有 力 :“PzNP”。 曾 经 有 许多 追逐 名 利 ( 克 雷 
数学 研究 所 提供 的 百 万 奖金 ) 的 人 给 出 了 PANP 问 题 的 各 种 “证 明 ”， 他 们 认为 P#NP 
或 P=NP，, 或 者 不 可 能 判定 P 是 否 等 于 NP, 或 者 声称 P/NP 问 题 根 本 就 之 无 道理 。 每 年 
都 会 涌现 很 多 这 类 证 明 的 手稿 有 的 被 发 送 到 计算 机 科学 家 的 电子 邮箱 里 ， 有 的 被 提 
交 到 学 术 期 刊 ,， 还 有 的 直接 公布 在 互联 网 上 。 最 著名 的 计算 机 科学 期 刊 持 续 地 收 到 声 
称 解决 了 P/NP 问 题 的 来 稿 ， 后来， 该 期 刊 宣布 了 一 条 对 这 些 文章 的 特殊 规定 。 










































































The Journal of the ACM (JACM ) 经 常 收 到 来 稿 ， 声 称 解 决 了 复杂 度 理 
论 领 域 一 个 长 期 悬而未决 的 问题 ， 即 P/NP 问 题 。 这 些 来 稿 严重 占用 了 JACM 
自愿 提供 的 编辑 和 审查 资源 ， 因 为 需要 一 定 的 时 间 才 能 辨识 其 中 的 错误 。 
JACM 仍 然 对 P/NP 及 相关 问题 的 解决 保持 开放 的 心态 ， 并 将 继续 欢迎 针对 这 
个 主题 的 投稿 。 然 而 ， 为 了 减轻 由 屡次 重复 提交 并 逐一 订正 错误 而 带 来 的 负 
担 ， 本 刊 决定 采取 如 下 规定 : 对 于 P/NP 这 个 复杂 度 理 论 领 域 长 期 未 解决 的 问 
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题 或 与 之 相关 的 主题 ， 任 何 作 者 在 24 个 月 的 周期 内 只 能 提交 一 篇 文章 ， 除 非 
受到 主编 的 约 稿 。 此 规定 也 适用 于 之 前 被 拒 稿件 的 再 次 提交 。 





在 这 些 对 解决 P/NP 问 题 的 尝试 中 ,大 部 分 要 么 不 知 所 云 ， 要 么 明显 是 错误 的 , 学 
术 界 对 此 基本 上 视而不见 。 而 德 奥 拉 利 卡 的 文章 则 受到 了 特殊 的 待遇 。 他 本 人 在 过 
曾 发 表 过 研究 论文 ,并 且 这 篇 论文 的 写作 水 平 超出 了 大 部 分 的 PNP 投 稿 。 于 是 有 的 理 
论 学 家 感到 有 必要 仔细 研读 一 下 这 篇 论文 。 这 在 互联 网 上 引起 了 轩然大波 , 一 些微 博 
和 博客 甚至 急 不 可 耐 地 提前 宣布 PINP 问 题 得 到 了 解决 。 几 个 著名 的 计算 机 科学 家 和 数 
学 家 在 仔细 研读 了 德 奥 拉 利 卡 的 论文 后 ， 发 现 了 其 中 的 几 处 缺陷 ， 有 一 些 是 小 玻 漏 ， 
另 一 些 则 是 大 错 特 错 。8 月 16 日 ， 也 就 是 论文 公布 后 的 第 10 天 ， 纽 约 时 报 发 表 了 一 篇 
文章 来 描述 事件 的 整个 过 程 ， 标 题 是 “第 1 步 : 发 布 模棱两可 的 证 明 ; 第 2 步 : 欣赏 烟 
火 表演 ”( Step 1: Post Elusive Proof. Step 2: Watch Fireworks )。 此 时 学 术 界 的 一 致意 见 
是 该 证 明 是 错误 的 ， 且 没有 修改 的 余地 。PNP 问 题 的 状态 仍然 是 悬而未决 。 
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希望 这 本 书 能 让 许多 读者 了 解 到 P/NP 问 题 的 重要 性 , 并 且 对 解决 这 个 问题 跃 跃 欲 
试 。 我 或 励 你 试 试 ， 因 为 如 果 不 亲自 尝试 ,很 难 真 正 理 解 一 个 问题 是 多 么 困难 。 要 注 
意 本 书 并 未 正式 地 定义 P/NP 问 题 , 如 果 读 者 真 的 想 求解 这 个 问题 ,首先 要 了 解 其 最 准 
确 的 表述 。 本 书 的 网 站 上 提供 了 几 个 很 好 的 资源 ， 供 读者 了 解 PNP 问 题 和 各 种 求解 学 
试 的 技术 细节 以 及 公理 化 描述 。 






































假设 你 真 的 找到 了 P/NP 问 题 的 解决 方法 , 该 怎么 通知 克 雷 数学 研究 所 ,让 他 们 把 
一 百 万 美元 的 支票 寄 过 来 呢 ? 先 别 急 。 你 几乎 不 可 能 有 合理 的 证 明 。 通 过 了 解 为 什么 
你 的 证 明 可 能 不 行 ， 你 说 不 定 会 得 到 局 迪 。 











下 面 我 就 描述 一 下 那些 认为 自己 证 明了 P/NP 问 题 的 人 通常 会 犯 哪些 错误 。 


早 在 1550 年 , 意大利 数学 家 吉 罗 拉 莫 :卡尔 达 诺 给 出 了 可 能 是 第 一 个 PNP 证 明 
的 反面 例子 。 卡 尔 达 诺 被 认为 是 概率 论 领 域 的 葛 基 人 之 一 ,在 宣传 他 发 明 的 一 种 新 的 
加 密 系 统 时 ， 他 声称 该 系统 绝对 安全 ， 因 为 密 钥 大多 ,无 法 逐个 检查 。 实 际 上 这 个 系 
统 非常 容易 破解 ， 因 为 对 加 密 的 消息 做 解密 分 析 时 根本 不 需要 检查 所 有 的 密 钥 。 











类 似 卡 尔 达 诺 所 犯 下 的 根本 性 错误 , 在 现在 证 明 Pz NP 的 尝试 中 屡见不鲜 。 再 次 
考虑 团 问题 。 一 类 证 明 的 思路 是 , 任何 试图 求解 团 问题 的 算法 在 找 不 到 一 个 有 效 解 时 ， 
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都 必须 确保 不 可 能 存在 给 定 人 数 的 团 。 唯一 可 行 的 方式 是 检查 所 有 可 能 的 人 组 成 的 集 
合 ， 然 后 检查 给 定 的 集合 是 否 成 团 。 由 于 集合 太 多 了 ,任何 算法 都 必须 花费 特别 长 的 
时 间 。 所 以 团 问 题 不 存在 高 效 的 解法 。 故 Pz NP -~ Q.E.D. ( Q.E.D. 是 拉丁 短语 quod erat 
demonstrandum 的 缩写 ， 意 为 “要 展示 的 就 是 这 么 多 ”， 常 用 于 数学 证 明 的 结尾 ， 表 示 


证 明 完 毕 。) 







































































这 种 思路 有 很 多 的 变种 。 而 其 中 的 逻辑 漏洞 在 于 “唯一 可 行 的 方式 ”。 算 法 可 行 
的 方式 也 许 非常 难以 捉摸 。 它 并 不 需要 按 你 认为 的 方式 工作 ,甚至 完全 不 用 遵守 问题 
本 身 的 内 在 结构 。 也 许 有 一 个 算法 ， 把 好 友 关 系 图 转化 成 某 些 奇怪 的 代数 表达 式 ， 当 
且 仅 当 团 存 在 时 才 存 在 某 一 类 型 的 解 。 虽 然 这 不 太 可 能 ,但 是 不 能 因为 你 认为 算法 不 
这 样 工 作 ， 就 排除 它 存在 这 样 的 可 能 性 。 























很 难 让 使 用 这 种 证 明 技巧 的 人 相信 他 (或 者 她 , 但 是 给 出 这 些 糟糕 证 明 的 人 几乎 
无 一 例外 全 部 都 是 男性 ) 是 不 对 的 。 他 们 总 会 反 过 来 要 我 写 出 一 个 不 用 穷 举 就 能 解 出 
团 问 题 的 算法 。 我 当然 写 不 出 来 ,能 写 出 来 不 就 意味 着 P= NP DUE, 况且 这 不 大 可 能 
是 真 的 。 但 证 明 的 负担 在 你 身上 ， 要 主张 你 给 出 的 证 明 的 合理 性 ， 你 需要 论证 不 存在 
以 其 他 方式 工作 的 算法 。 


























而 要 证 明 P = NP ,“ 只 需 ” 给 出 某 个 NP 完全 问题 的 有 效 算法 。 于 是 很 多 人 会 给 出 
团 问题 的 一 个 算法 , 然后 就 说 他 们 证 明了 P= NP 。 但 是 一 个 算法 本 身 并 不 构成 一 个 证 
明 。 必 须 还 要 形式 化 地 论证 该 问题 的 每 一 个 实例 ， 即 在 所 有 可 能 的 好 友 关 系 图 上 ， 该 
算法 都 能 高 效 地 运行 ， 并 给 出 正确 的 答案 。 而 这 些 证 明 的 尝试 要 么 没有 覆盖 所 有 可 能 
的 情况 ， 要 么 本 身 就 是 错误 的 或 不 完整 的 。 给 出 的 算法 不 是 结果 是 错误 的 ， 就 是 在 复 
杂 的 实例 上 无 法 高 效 地 运行 。 




















7.4 现状 





我 们 离 证 明 Pz NP 比 以 前 更 远 了 。 虽然 对 该 问题 了 解 更 深入 了 , 但 从 某 种 程度 上 
讲 ， 在 未 来 一 段 时 间 内 ， 都 不 存在 未 被 尝试 过 的 明显 的 方法 和 已 知 的 证 明 思 路 了 。 


























目前 唯一 已 知 的 有 可 能 解决 PNP 问 题 的 方法 ,来 自 芝加哥 大 学 的 山 坦 马尔 马 
利 。 他 的 工作 表明 通过 解决 代数 几何 学 〈 它 比 高 中 的 代数 和 几何 要 复杂 得 多 ) 这 一 数 
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学 领域 的 革 些 问题 , 可 能 会 产生 Pz NP 的 证 明 。 但 是 求解 这 些 代数 几何 学 问题 所 需 的 
数学 技术 远 远 超出 了 今天 人 类 的 数学 技术 水 平 。 几 年 前 马尔 马 利 觉得 他 的 程序 要 100 
年 才能 跑 完 。 如 今 他 认为 之 前 想 得 有 点 乐观 了 。 


还 要 过 多 久 我 们 才能 看 到 P/NP 问 题 真 正 得 到 解决 ?也许 在 你 读 到 本 书 的 时 候 这 
个 问题 已 经 被 解决 了 。 但 更 有 可 能 的 是 , 很 长 一 段 时 间 内 它 都 无 法 被 解决 ， 也 许 比 费 
马 大 定理 从 提出 到 解决 所 经 历 的 357 年 更 长 ， 甚 至 有 可 能 一 直 得 不 到 解决 ， 成 为 数学 
和 科学 领域 一 个 永远 的 未 解 之 这 。 











Bmw 





每 个 人 都 有 秘密 ， 从 密码 到 电子 邮件 , 我 们 都 有 不 想 让 别人 看 到 的 东西 。P s NP 
意味 着 某 些 NP 问 题 拥 有 不 为 人 知 的 秘密 , 无 法 很 快 找到 它 的 答案 。1976 年 ， 惠 特 菲 尔 
德 . 迪 菲 和 马丁 : 赫 尔 曼 提出 可 以 用 NP 问 题 来 隐藏 我 们 自己 的 秘密 。 从 此 ， 密 码 学 这 
门 研究 秘密 消息 的 学 科 发 生 了 质 的 改变 。 



































秘密 消息 的 历史 和 人 们 传递 消息 的 历史 一 样 入 远 。 朱 利 叶 斯 :凯撒 使 用 过 一 个 简 
单 的 替换 加 密 算 法 ， 即 将 每 个 字母 替换 为 它 在 字母 表 位 置 往 后 数 第 三 个 位 置 的 字母 。 


























The early bird gets the worm ( 早起 的 乌 儿 有 虫 吃 ) 就 变 成 了 Wkh hduob elug jhwv 
wkh zrup。 这 种 字母 奉 换 的 加 密 方 法 被 称 为 凯 撤 密码。 
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图 8-1 凯撒 密码 

















这 种 技术 在 古 罗马 非常 好 用 , 加 过 密 的 消息 看 起 来 像 是 胡言 乱 语 ， 而 那 时 人 们 有 
限 的 技术 还 无 法 破译 这 种 密码 。 到 了 公元 9 世纪 ， 数 学 家 发 现 了 通过 统计 字母 和 短 字 
的 频率 来 破解 密码 的 方法 。 我 们 来 看 Wkh hduob elug jhwv wkh zrup ， 注 意 其 中 字母 h 
出 现 了 4 次 ， 比 其 他 字母 都 多 。 英 语 中 出 现 频率 最 高 的 字母 是 e， 所 以 可 以 (正确 地 ) 
推测 p 代 表 e。 然 后 注意 到 Wkh 出 现 了 2 次 ， 而 如 果 h 代 表 e， 那 么 可 以 推测 Wkh 代 表 the。 
按 此 方法 ， 很 快 就 能 破译 这 条 消息 。 
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在 15 世 纪 的 意大利 文艺 复兴 时 期 ， 莱 昂 . 巴 蒂 斯 塔 . 阿尔 伯 蒂 创造 了 一 种 更 为 复 
杂 的 加 密 方法 ， 称 为 多 字母 加 密 法 (polyalphabetic cipher )， 对 消息 的 不 同 部 分 使 用 不 
同 的 替换 规则 。 这 些 密码 在 很 长 一 段 时 间 内 都 无 法 被 破解 ， 直 到 19 世 纪 人 们 发 展 出 了 
更 系统 化 的 密码 破译 方法 。 














作家 兼 许 人 埃 德 加 ' 爱 伦 . 坡 也 对 密码 分 析 颇 有 研究 。1839 年 他 公开 征集 难以 破 
译 的 密码 ， 以 供 他 研究 密码 破译 的 方法 。 一 年 后 ， 爱 伦 * 坡 发 表 了 一 篇 名 为 “ 谈 谈 秘 
密 写作 ”( A Few Words on Secret Writing ) 的 文章 ， 他 在 其 中 声称 “人 类 的 创造 力 无 法 
创造 自身 不 能 破译 的 密码 ”。 他 在 1843 年 的 小 说 《 金 甲虫 》( The Gold-Bug ) 中 就 有 破 
译 密码 的 情节 ， 它 属于 第 一 批 描 述 密码 的 小 说 。 














1903 年 亚 瑟 ' 柯南 道 尔 发 表 了 《跳舞 的 小 人 》( The Adventure of the Dancing 
Man )， 这 本 小 说 讲述 了 吹 洛 克 … 福尔摩斯 如 何 破译 一 个 由 火柴 棍 小 人 构成 的 替换 


KYPXEXE AXSAEEIS 


图 8-2 ”跳舞 的 小 人 


























随 着 机 械 时 代 的 到 来 ， 出 现 了 一 批 加 密 和 解密 消息 的 机 器 设备 。 其 中 最 知名 的 
可 能 要 数 恩 尼 格 玛 密码 机 (Enigma machine )， 是 德国 人 亚 瑟 . 谢 尔 比 乌 斯 在 1918 
年 发 明 的 。 




















恩 尼 格 玛 密码 机 有 数 个 转子 , 在 打字 过 程 中 , 这 些 转子 将 字母 替换 成 其 他 的 字母 。 
于 每 个 转子 的 转速 不 同 ， 每 一 个 字母 具有 不 同 的 蔡 换 规则 。 这 个 机 融 可 以 看 做 是 阿 
尔 伯 带 的 多 字母 加 密 法 的 一 个 更 复杂 的 版 本 ， 用 它 加 密 的 消息 非常 难以 破译 。 












































恩 尼 格 玛 密码 机 是 第 二 次 世界 大 战 中 德军 使 用 的 主要 密码 来 源 。 在 开战 之 前 ， 波 
兰 军事 情报 机 构 向 英国 提供 了 该 机 器 的 描述 和 一 些 破译 技术 。 英 国政 府 随 即 局 动 了 一 
项 代号 为 “超级 ”( Ultra ) 的 计划 来 破解 密码 。 征 募 的 研究 人 员 有 纵横 填 字 和 国际 象 
棋 高 手 ， 也 有 大 数学 家 ， 其 中 包括 计算 学 之 父 阿 兰 ， 图 灵 。 第 一 台 可 编程 电子 计算 机 
"ELA" (Colossus ) 就 是 在 计划 的 实施 过 程 中 诞生 的 。 温 斯 顿 ， 丘吉尔 兽 说 :“ 是 “ 超 
级 ”计划 让 我 们 赢得 了 战争 。 
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图 8-3” 恩 尼 格 玛 密 码 机 





密码 学 从 诞生 以 来 都 是 〈 而 且 将 来 也 是 ) 一 场 猫 鼠 游戏 ， 即 密码 制造 者 和 密码 破 
译 者 双 方 的 斗智 斗 勇 。 但 是 在 20 世 纪 70 年 代 ， 随 着 计算 机 科学 家 开始 构造 基于 难以 求 
解 的 NP 问 题 的 加 密 方 法 ， 这 个 游戏 的 格局 发 生 了 重大 变化 。 








82 ”现代 密码 学 











“我 们 今天 正面 临 着 一 场 密码 学 的 革命 。” 这 是 1976 年 斯 坦 福 大 学 的 惠 特 菲 尔 
德 . HAE RU T 赫 尔 曼 所 发 表 的 著名 论文 中 的 开题 句 。“ 廉 价 电子 硬件 制造 技术 的 
进展 将 密码 学 从 使 用 机 械 进行 计算 所 带 来 的 设计 局 限 中 解放 出 来 , 让 曾经 蝇 贵 的 高 端 
加 密 设 备 变 得 成 本 低廉 ， 使 得 远程 提 款 机 、 计 算 机 终端 等 商业 化 应 用 成 为 可 能 。 
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迪 菲 和 赫 尔 曼 认识 到 了 , 计算 机 可 以 让 复杂 的 加 密 通 信 协 议 以 成 本 低廉 的 软件 形 
态 存在 。 但 同时 计算 机 也 带 来 了 很 多 挑战 。 随 着 计算 机 与 计算 机 之 间 的 网 络 得 到 普及 ， 
必须 要 开发 出 一 种 高 效率 且 低 成 本 的 安全 通信 方法 。 迪 菲 和 赫 尔 曼 在 谈 到 近 十 年 来 
PNP 问 题 的 进展 时 说 道 :“ 同 时 ， 信 息 论 和 计算 机 科学 的 理论 进展 很 有 和 希望 提供 一 种 
安全 的 加 密 方法 ， 从 而 将 密码 学 这 门 古老 的 艺术 变 为 一 门 科学 。” 





















































在 迪 菲 和 赫 尔 曼 之 前 的 时 代 ， 要 解密 一 条 消息 必须 使 用 加 密 它 的 密 钥 。 如 果 一 位 
将 军 通 过 恩 尼 格 玛 密码 机 向 战场 上 的 一 位 上 尉 发 送 消 息 ， 双 方 必须 事先 约定 好 机 需 的 
设置 ， 即 转子 在 消息 开头 的 初始 参数 。 上 有 尉 会 随身 携带 一 个 密码 本 ， 里 面 记录 了 每 天 
更 换 的 设置 参数 。 如 果 这 个 本 子 落 入 敌手 ,秘密 通信 就 必须 停止 ,直到 发 放 一 套 新 的 
密码 本 。 士 兵 们 平时 会 悉心 保管 这 些 本 子 ， 一 旦 被 俘 就 立即 销毁 它们 。 所 以 并 不 需要 
经 常 更 换 新 的 密码 本 。 






























































计算 机 网 络 带 来 了 新 的 挑战 ， 因 为 不 能 想当然 地 认为 网 络 是 安全 的 。20 世 纪 末 的 
计算 机 网 络 通常 会 在 某 些 区 域 通过 普通 电话 线 来 传输 ， 而 电话 线 是 很 容易 被 窃听 的 。 
即使 是 今天 ， 坐 在 咖啡 馆 另 一 头 的 人 也 可 以 读 取 你 使 用 免费 Wi-Fi 所 发 送 的 全 部 数据 。 























不 能 用 网 络 来 发 送 密 钥 ， 否 则 之 后 的 通信 变 得 不 安全 。 在 开始 和 某 人 秘密 通信 前， 
必须 要 用 某 种 物理 的 方法 将 密 钥 送 到 那个 人 手 上 。 而 这 样 做 的 经 济 和 时 间 成 本 都 很 高 。 





在 前 人 罗 杰 ' 默 克 尔 工 作 的 基础 上 ， 迪 菲 和 赫 尔 曼 提出 了 解决 这 个 问题 的 一 种 方 
法 ， 他 们 称 之 为 “ 公 钥 ”加 密 。 计 算 机 生成 两 把 钥匙 ， 一 把 公 钥 ， 一 把 私 钥 。 计 算 机 
自己 储存 好 私 钥 ， 绝 不 把 它 泄露 到 网 上 。 公 钥 则 通过 网 络 广播 给 所 有 人 。 
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息 变 成 一 串 密码 。 公 钥 不 能 用 来 解密 消息 ， 只 有 私 钥 可 以 解密 消息 。 

















假如 迪 菲 想 发 送 一 条 秘密 消息 “中 午 进攻 ”给 赫 尔 曼 ， 首 先 赫 尔 曼 要 生成 私 钥 和 
公 钥 。 然 后 赫 尔 曼 把 公 钥 发 送 给 迪 菲 (也 发 送 给 所 有 可 能 正在 监听 的 人 )， 私 钥 则 自己 
留 着 。 然 后 迪 菲 用 赫 尔 曼 的 公 钥 把 消息 “中 午 进 攻 ” 加 密 为 密码 “tzljcnnfekktis”"， 并 
把 密码 “tzljcnnfekktis” 发 送 给 赫 尔 曼 。 过 非 在 加 密 时 不 需要 知道 私 钥 ， 只 需 使 用 公 钥 。 
窃听 者 能 看 到 加 密 的 字符 串 “tzljcnnfekktis”, 但 是 上 只 知道 公 钥 是 不 能 恢复 原始 消息 的 。 
赫 尔 曼 则 可 以 用 自己 的 私 钥 把 “ftzljcnnfekktis” 人 恢复 成 原始 的 消息 ， 即 “中 午 进 攻 ”。 
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公 钥 加 密 有 可 能 实现 吗 ? WMR P= NP 那 就 不 可 能 ， 因 为 会 存在 一 个 高 效 的 算法 ， 
通过 公 钥 来 计算 出 私 钥 。 


而 即使 是 在 1976 年 , 大 多 数 计算 机 科学 家 也 认为 Pz NP , 在 此 前 提 下 公 钥 加 密 是 
可 能 的 。 迪 菲 和 赫 尔 曼 首创 了 公 钥 加 密 系 统 ， 但 是 他 们 提出 的 通信 协议 不 如 另 一 个 协 
议 流 行 ， 该 协议 由 罗 纳 德 ， 李维斯 特 、 阿 迪 … 沙 米尔 和 伦 纳 德 . 阿 德 曼 三 位 计算 机 
科学 家 于 1978 年 发 明 ， 并 以 三 人 的 姓 缩写 命名 为 RSA。 














RSA 加 密 协议 基于 这 样 一 个 想法 ， 即 计算 乘积 容易 ， 分 解 因数 则 很 难 。 随 机 挑选 
两 个 大 的 质数 ,比如 5 754 853 343 和 2 860 486 313, 很 容易 计算 其 乘积 为 16 461 679 220 
973 794 359。 男 一 方面 ， 很 难 北 转 这 个 运算 ， 即 把 16 461 679 220 973 794 359 分 解 为 
5 754 853 343 乘 以 2 860 486 313。RSA 使 用 了 比 这 大 得 多 的 数 ， 通 常 有 几 百 位 长 。 虽 
然 说 如 果 不 证 明 Pz NP ,就 无 法 证 明 因 数 分 解 本 质 上 是 一 个 难以 计算 的 问题 , 但 大 部 
分 人 都 认为 因数 分 解 是 一 个 困难 的 问题 。 

































































罗 纳 德 . 李维斯 特 、 阿 迪 … 沙 米尔 和 伦 纳 德 . 阿 德 曼 因 为 发 明 该 协议 ， 分 享 了 
2002 年 的 图 灵 奖 。 











有 一 个 小 插曲 ， 其 实 RSA 协 议 最 早 是 在 1973 年 被 克利 福 德 . 柯 克 斯 发 明 的 ， 他 为 
英国 政府 通信 总 部 工作 , 该 机 构 相 当 于 美国 的 国家 安全 局 。 这 个 事实 直到 1997 年 才 被 
公之于众 。 

















你 可 能 每 天 都 在 用 RSA 加 密 协 议 。 随 便 看 一 个 网 站 ( 结果 可 能 因 浏 览 器 差异 而 不 同 )。 





8-4 ”Facebook 网 站 的 地 址 栏 


注意 到 https 协 议 中 的 s 以 及 后 面 的 小 锁 标 识 。 


facebook 





图 8-5 ”被 标记 的 Facebook 网 站 的 地 址 栏 
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s 代 表 secure( 安全 )。Facebook 公 布 了 一 把 公 钥 。 浏 览 器 会 把 用 户 输 入 的 密码 用 公 
钥 加 密 。 加 密 过 的 密码 被 发 送 给 Facebook。 所 以 咖啡 馆 里 的 人 即使 用 笔记 本 电脑 监测 所 
有 用 Wi-Fi 传 输 的 数据 ， 也 无 法 猿 出 用 户 的 密码 。Facebook 用 私 钥 可 以 解密 用 户 的 密码 。 
同样 地 ， 用 户 的 浏览 器 也 生成 一 对 公 钥 和 私 钥 ， 把 公 钥 发 送 给 Facebook。 这 样 Facebook 
就 可 以 向 用 户 发 送 经 过 加 密 的 好 友 状 态 更 新 数据 ， 除 了 用 户 自己 别人 都 看 不 到 。 




















8.3 P=NP 下 的 密码 学 











如 果 我 们 生活 在 第 2 章 描 述 的 “美妙 世界 ”中 ， 密 码 学 会 发 生 怎 样 的 变化 ?我 们 很 
容易 算出 5 754 853 343 和 2 860 486 313 是 否 为 质数 ， 以 及 5 754 853 343x 2 860 486 313 = 
16 461 679 220 973 794 359。 我 们 甚至 能 在 几 千 位 或 几 百 万 位 的 数 上 做 这 些 运算 。 由 
于 我 们 可 以 验证 因数 分 解 问题 的 解 ， 故 该 问题 属于 NP。 如 果 P= NP ， 那 么 因数 分 解 
问题 将 变 得 能 被 高 效 地 计算 , 我 们 可 以 找到 几 百 万 位 数 的 质数 因子 。P = NP 将 让 RSA 
协议 失效 。 所 有 基于 公 钥 加 密 系 统 的 协议 也 都 将 失效 。P = NP 意味 着 如 果 不 和 对 方 事 
先 联系 好 ， 你 将 无 法 向 任何 人 发 送 秘密 消息 。 




















难道 密码 学 将 在 美妙 世界 中 毫 无 用 武之 地 吗 ?” 只 有 一 个 方法 可 行 , 就 是 一 次 性 密 
码 本 (one-time pad )， 它 的 安全 性 是 理论 上 可 被 证 明 的 ， 而 且 不 依赖 于 NP 问 题 的 困难 
程度 。 假设 艾 莉 丝 有 一 个 12 个 字符 的 密码 FIDDLESTICKS。 所 谓 的 密码 本 是 一 个 长 度 
相同 的 随机 字符 串 JXORMQNAMRHC。 从 密码 和 字符 串 中 分 别 取出 第 一 位 的 字母 ，F 
和 J， 两 者 分 别 是 字母 表 中 第 6 个 和 第 10 个 字母 。 将 两 者 的 排序 相 加 得 到 16， 然 后 用 第 
16 个 字母 P 作 为 加 密 的 第 一 个 字母 。 再 分 别 取出 第 二 位 的 字母 ,， I 和 XX， 字母 表 中 序号 
分 别 为 9 和 24， 相 加 得 到 33。 字 母 表 中 没有 33 个 字母 ， 于 是 减 去 26， 得 到 7， 然 后 用 第 
7 个 字母 G 作 为 加 密 的 第 二 个 字母 。 以 此 类 推 ， 就 可 得 到 加 密 的 字符 串 
PGSVYVGUVUSV。 艾 莉 丝 把 加 密 的 字符 串 发 送 给 Facebook。Facebook 只 须 减 去 而 不 
是 加 上 密码 本 中 的 每 一 位 ， 就 可 解密 这 条 消息 。 


































































































由 于 长 度 为 12 的 一 次 性 密码 本 和 消息 一 样 多 ， 所 有 加 密 字符 串 的 概率 都 是 相等 
的 ， 数 学 上 无 法 通过 密码 本 对 消息 本 身 有 任何 了 解 ， 无 论 是 否 P=NP ,结论 都 成 立 。 
那 为 什么 我 们 不 都 用 一 次 性 密码 本 加 密 ， 而 要 使 用 更 加 复杂 ， 而 且 有 可 能 被 破解 的 因 
数 分 解 加 密 方法 呢 ? 
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使 用 一 次 性 密码 本 必须 十 分 小 心 。 顾 名 思 义 ， 一 次 性 密码 本 只 能 被 使 用 一 次 。 甚 
至 两 个 不 同 的 人 分 别 向 另外 两 个 不 同 的 人 发 送 秘密 消息 ， 都 最 好 不 要 用 同一 个 密码 
本 ， 和 否则 不 能 保证 这 两 条 消息 的 安全 性 。 每 个 密码 本 都 至 少 要 和 消息 一 样 长 。 没 有 公 
钥 和 私 钥 之 分 ， 只 有 一 份 共享 的 私 钥 ( 即 密码 本 JXORMQNAMRHC )。Facebook 和 艾 
莉 丝 都 必须 知道 密码 本 ,但 如 果 和 窃听 者 知道 了 密码 本 的 一 小 部 分 ， 他 就 能 获知 部 分 的 
消息 。 Facebook 需 要 把 密码 本 以 某 种 别人 看 不 到 的 方式 交 给 艾 莉 丝 ( 反 过 来 也 是 如 此 )。 
由 于 人 们 能 监听 互联 网 通信 ， 所 以 Facebook 或 某 个 受信 任 的 第 三 方 不 得 不 将 密码 本 存 
在 U 盘 或 者 其 他 物理 设备 中 然后 交 给 艾 莉 丝 。 我 能 想象 , 美妙 世界 中 的 艾 莉 丝 会 从 杂货 
店 买 一 个 密封 的 U 盘 , 里 面 装 满 了 一 次 性 密码 本 。U 盘 会 由 某 些 受 信任 的 组 织 来 生产 ( 美 
国政 府 ? )， 并 保证 以 安全 的 方式 将 同样 的 密码 本 发 送 给 Facebook 或 其 他 公司 。 






























































Facebook 也 可 以 用 量子 力学 来 生成 密码 本 并 将 其 传输 给 艾 莉 丝 。 我们 在 下 一 章 会 
讲 讲 量子 密码 学 ， 但 这 个 方法 可 能 会 因为 成 本 过 高 而 无 法 被 广泛 使 用 。 
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图 8-6 FARAR 


鲍 勃 痛苦 地 喊 道 :“ 报 纸 一 定 弄 错 了 ， 这 个 数 独 不 可 能 有 解 !” 他 的 同事 艾 莉 丝 听 
到 了 ， 过 来 看 了 一 眼 。 她 在 早 班车 上 解 出 了 同一 道 题 ， 所 以 她 知道 饱 勃 是 错 的 。 艾 莉 
丝 的 解 如 下 。 
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图 8-7” 零 知识 数 独 的 解 
鲍 勃 正 打算 放弃 这 个 谜 题 ， 于 是 艾 莉 丝 说 她 能 解 出 这 道 题 ， 但 鲍 勃 不 相信 。 艾 莉 
丝 知道 饮 勃 看 到 明天 公布 在 报纸 上 的 答案 时 将 会 很 诅 丧 , 所 以 她 想 让 饱 勃 继续 尝试 下 
去 。 她 可 以 向 鲍 勃 展示 自己 的 答案 ,但 这 将 毁 掉 鲍 勃 破解 迷 题 的 乐趣 。 艾 莉 丝 想 在 不 
透露 任何 答案 信息 的 前 提 下 ， 让 鲍 勃 相信 这 个 数 独 谜 题 是 有 解 的 。 

















幸运 的 是 艾 莉 丝 在 大 学 里 主 修 计算 机 科学 ， 她 知道 零 知 识 证 明 。 她 设计 了 如 下 这 
个 方案 。 





首先 , 艾 莉 丝 回 到 自己 的 办 公 隔 间 , 不 让 鲍 勃 看 见 她 。 艾 莉 丝 随机 重新 排列 了 1 ~ 9 
的 数字 。 


重 排 前 | 重 排 后 






































1 9) 
2 8 
3 6 
4 5 
5 4 
6 9 
7 1 
8 7 
9 3 
图 8-8 cy 








然后 她 把 自己 的 解 按 上 表 进 行 数字 替换 〈 用 2 代替 1，3 代 替 9， 等 等 )， 然 后 
果 写 到 一 大 张 纸 上 。 
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图 8-9 ”经 过 重新 排列 的 零 知 识 数 独 





然后 艾 莉 丝 仔 细 地 把 纸 剪 成 81 片 ， 每 片上 有 一 个 数字 。 她 把 每 片 纸 放 到 一 个 小 袋 


子 里 ， 并 把 袋子 按 数字 原来 的 顺序 放 在 一 个 空白 的 网 格 上 。 
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图 8-10 ”被 遮盖 的 零 知 识 数 独 


























最 左上 角 的 袋子 里 装着 数字 2， 它 右边 的 袋子 装着 数字 3 ， 等 等 。 














艾 莉 丝 小 心地 把 网 格 和 袋子 带 到 鲍 勃 那里 ， 解 释 了 刚才 她 做 的 寻 





字 重 排 前 后 的 对 应 关系 )， 并 证 鲍 勃 从 28 个 检验 方法 中 选择 一 种 。 





a 从 9% 行 中 选择 一 行 ， 打 开 那 行 的 所 有 袋子 。 
a 从 9 列 中 选择 一 列 ， 打 开 那 列 的 所 有 袋子 。 
a 从 9 个 3 x 3 的 方 格 中 选择 一 个 ， 打 开 里 面 的 所 有 袋子 。 

















ei ( 没有 透露 数 
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图 8-11 打开 一 行 的 零 知 识 数 独 
如 果 艾 莉 丝 有 一 个 解 ， 并 且 做 了 她 说 的 那些 操作 ,那么 饱 勃 看 到 的 应 该 是 1 ~ 9 这 


几 个 数字 不 重复 的 随机 排列 。 如 果 饱 勃 看 到 两 个 相同 的 数字 ,， 那 他 就 知道 艾 莉 丝 作 丈 
了 ， 但 是 这 里 艾 莉 丝 通过 了 测试 。 


























鲍 勃 大 选择 列 或 方 格 也 有 同样 的 检验 策略 。 


如 果 鲍 勃 选 择 最 后 一 种 检验 方法 ， 即 “选择 那些 处 在 原来 迷 题 中 已 知 数字 位 置 上 
的 袋子 ， 并 打开 它们 ”。 他 看 到 的 如 下 图 所 示 。 















































图 8-12 ”打开 已 知 数字 对 应 位 置 的 零 知 识 数 独 
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当 且 仅 当 鲍 勃 选择 做 这 项 测试 时 ,， 艾 莉 丝 会 把 数字 重 排 前 后 的 对 应 关系 表 展 示 给 
BV. 








重 排 前 | EHF 

















图 8-13 ”数字 




















然后 鲍 勃 就 可 以 检查 打开 位 置 的 数字 与 恋 题 中 原来 已 知 数字 的 对 应 关系 是 否 如 
表 中 所 示 。 根 据 此 表 ， 原 题 中 的 数字 9 应 该 对 应 袋 中 的 数字 3 ， 果 然 如 此 。 





如 果 艾 莉 丝 真 的 有 一 个 解 并 且 做 了 她 说 的 那些 操作 ,她 就 会 通过 所 有 的 测试 。 鲍 
动 从 中 得 知 了 什么 ”如果 鲍 勒 选择 查看 茶 一 行 、 列 或 方块 ,他 只 能 够 看 到 随机 排列 的 
1 ~9， 没 有 任何 对 解 题 有 用 的 信息 。 























如 果 鲍 勃 选 择 了 最 后 一 个 测试 ， 他 会 看 到 原来 谜 题 的 一 个 随机 重 排 ,也 没有 任何 
对 解 题 有 用 的 信息 。 





要 是 艾 莉 丝 没有 一 个 真正 的 解 会 怎样 呢 ? 那 无 论 艾 莉 丝 怎么 做 , 都 不 可 能 通过 鲍 
勃 可 能 选择 的 所 有 测试 。 如 果 鲍 勃 随机 选择 的 话 ， 艾 和 莉 丝 有 至 少 1128〈 即 3.57% ) 的 
概率 被 抓 到 作弊 。 上 听 起 来 这 个 概率 挺 低 的 ， 但 如 果 艾 莉 丝 和 鲍 勃 重复 83 次 测试 〈 每 次 
都 选择 一 个 新 的 数字 对 应 关系 )， 艾 莉 丝 至 少 有 1 次 不 能 通过 测试 的 概率 将 超过 95%。 


















































鲍 勃 终于 相信 艾 莉 丝 解 出 了 这 道 数 独 迹 题 ， 但 是 他 得 到 的 是 关于 解 的 “ 零 知 识 ”， 
即 除了 知道 存在 一 个 解 之 外 一 无 所 知 。 鲍 勃 可 以 继续 求解 这 道 谜 题 ， 并 相信 它 是 有 解 
的 ， 但 这 对 于 找到 答案 没有 任何 帮助 。 
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在 这 个 例子 里 ， 鲍 勃 不 愿意 了 解 艾 莉 丝 的 解 的 任何 细节 。 但 在 理论 上 ， 鲍 勃 可 以 
通过 抓 起 所 有 袋子 并 打开 它们 来 作弊 。 为 了 避免 这 种 情况 ， 艾 莉 丝 可 以 用 上 锁 的 箱子 
来 代替 袋子 ， 并 且 只 给 鲍 勃 他 选择 的 那些 箱子 的 钥匙 。 


要 是 鲍 勃 和 艾 莉 丝 不 在 同一 个 办 公 室 ， 而 是 位 于 不 同 的 城市 呢 ? 他 们 仍 可 以 轻松 
地 通过 电话 或 电子 邮件 交流 ， 但 是 怎么 来 表示 袋子 呢 ? 他 们 可 以 使 用 简单 的 加 密 技 
术 。 艾 莉 丝 为 每 一 个 袋子 选 一 个 不 同 的 随机 大 数字 , 其 最 后 一 位 和 袋子 里 的 数字 相同 ， 
比如 为 装 有 数字 2 的 袋子 选择 3 682 502。 然 后 艾 莉 丝 用 她 的 公 钥 为 这 些 数字 加 密 ， 把 
它们 发 送 给 鲍 勃 。 鲍 勃 选 好 做 哪 项 测试 后 ， 艾 莉 丝 给 出 鲍 勃 选择 的 袋子 对 应 的 解密 后 
的 值 。 鲍 勃 可 以 用 艾 莉 丝 的 公 钥 重新 加 密 这 些 数字 ， 然 后 检查 是 否 与 之 前 发 送 的 加 密 
值 相符 。 













































































正如 我 们 在 第 4 章 看 到 的 ， 数 独 是 NP 完 全 问题 ， 即 每 一 个 NP 问 题 都 能 归 约 到 数 独 
问题 。 所 以 我 们 就 自动 有 了 每 一 个 NP 问 题 的 零 知 识 系统 。 艾 莉 丝 可 以 说 服 鲍 勃 在 敌 友 
国 存在 一 个 很 大 的 团 , 可 以 用 三 种 颜色 填充 某 张 地 图 , 或 存在 一 条 很 短 的 旅行 商 路 线 ， 
同时 只 透露 团 、 填 色 方 法 或 路 线 的 零 知 识 ， 即 它们 是 存在 的 这 个 事实 。 











密码 学 攻击 中 常用 的 方法 是 通过 冒充 别人 来 蒙混 过 关 。 零 知 识 证 明 则 提供 了 一 种 
防卫 这 种 身份 欺骗 的 方法 。 艾 莉 丝 使 用 自己 的 公 钥 加 密 一 些 随 机 选择 的 个 人 机 密 信 
息 。 艾 莉 丝 想 向 鲍 勃 证 明 她 的 身份 。 如 果 她 直接 把 这 些 秘密 告诉 鲍 勃 ,那么 理论 上 鲍 
勃 就 有 了 冒充 艾 莉 丝 的 机 会 。 而 如 果 艾 莉 丝 提供 的 是 一 些 零 知识 证 明 ,， 那么 她 不 仅 能 
让 鲍 勃 相信 她 知道 这 些 秘密 ， 更 重要 的 是 没有 透露 自己 的 任何 秘密 。 这 样 鲍 勃 就 能 在 
不 知道 艾 莉 丝 个 人 机 密 信息 的 前 提 下 确认 对 方 的 身份 。 





























8.5 Eu 


鲍 勃 和 艾 莉 丝 正 在 商量 晚餐 去 哪里 吃 。 鲍 勃 想 吃 牛排 ， 而 艾 莉 丝 想 吃 鱼 。 他 们 决 
定 抛 硬 币 来 选择 餐馆 。 鲍 勃 抛 起 硬币 ， 然 后 把 它 扣 在 有 骆 膊 上 。 艾 莉 丝 猜 正面 。 鲍 勃 拿 
开 闭 在 硬币 上 的 手 ， 是 反面 ， 于 是 两 人 去 吃 牛 排 。 


听 起 来 挺 公平 ,不 过 要 是 艾 莉 丝 和 鲍 勃 是 通过 电话 或 互联 网 联络 怎么 办 ? 鲍 勃 可 
能 会 对 硬币 结果 撒谎 ， 甚 至 根本 不 抛 硬币 。 艾 莉 丝 如 何 才能 确认 过 程 是 公平 的 ? 
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一 个 办 法 是 用 公开 的 随机 信息 。 鲍 勃 和 艾 莉 丝 可 以 商定 如 果 当 天 道琼斯 工业 指数 
的 收盘 价 最 后 一 位 是 奇数 ,那么 由 鲍 勃 来 选 餐 厅 ， 如 果 是 偶数 则 由 艾 莉 丝 说 了 算 。 但 
这 个 方法 在 星期 六 就 失效 了 ， 股 市 不 开盘 。 









































这 里 介绍 一 种 使 用 密码 学 的 方法 ， 用 到 了 我 们 在 本 章 前 面 讲 到 的 公 钥 加 密 。 首 先 
由 饱 勃 生成 公 铀 和 私 钥 ， 然 后 随机 选 一 个 数 ， 如 69 441 251 920 931 124， 把 它 用 公 钥 
加 密 。 鲍 勃 把 公 铀 和 加 密 过 的 消息 发 给 艾 莉 丝 。 





然后 轮 到 艾 莉 丝 来 猜 饱 勃 的 数字 是 奇数 还 是 偶数 ,并 把 结果 发 给 饱 勃 。 之 后 鲍 支 
把 私 钥 发 送 给 艾 莉 丝 ， 后 者 用 它 解密 信息 ， 发 现 鲍 勃 选 定 的 数字 是 69 441251920931 
124。 知 艾 莉 丝 猜 的 是 偶数 ， 那 她 就 赢 了 ; 如 果 她 猜 的 是 奇数 ， 那 鲍 勃 就 赢 了 。 



































为 什么 这 个 方案 能 奏效 呢 ? 在 艾 莉 丝 选 择 猜 奇数 或 偶数 之 前 , 鲍 勃 选 好 了 一 个 数 
69 441 251 920 931 124。 艾 莉 丝 在 猜 的 时 候 不 知道 鲍 勃 选 的 是 什么 数 。 艾 莉 丝 只 能 看 
见 加 密 过 的 消息 ， 除 非 能 破解 密码 ， 和 否则 她 对 饱 勃 选择 的 数 一 无 所 知 。 所 以 艾 莉 丝 只 
能 随便 猜 。 另 一 方面 ， 饱 勃 无 法 改变 选 定 的 数 ， 因 为 之 前 已 经 把 它 的 加 密 版 本 发 给 
莉 丝 了 。 艾 和 莉 丝 猜 完 后 鲍 勃 通过 发 送 私 钥 来 公布 答案 。 如 果 双 方 都 随机 地 进行 游戏 ， 
那么 胜率 应 该 是 五 五 平分 的 。 只 要 公 钥 加 密 系 统 是 安全 的 ， 就 没有 人 能 作 次 。 

















抛 硬 币 这 个 游戏 太 简单 了 ,那么 对 于 复杂 点 的 游戏 情况 又 如 何 呢 ? 


鲍 勃 和 艾 莉 丝 能 通过 电话 下 国际 象棋 吗 ? 可 以 , 而且 很 容易 一 一 每 个 人 轮流 用 标 
国际 象棋 记 谱 法 告诉 对 方 自己 的 行动 即 可 。 





x 











他 们 能 下 西洋 双 陆 棋 ( backgammon ) 或 强手 棋 ( Monopoly ) 14? fi rfe ae T 
才能 让 艾 莉 丝 信服 ? AT ARAETA, IERA T E AIET HN. 











fil] Ath ce AERE ix OERE Y. ERA E 
fHBI—EPCBEBLXEPERUSR, EUG REBEL, MAANI; MRA KREN 
些 牌 。 还 要 有 一 些 两 个 玩家 都 能 看 到 的 牌 ， 以 及 一 些 两 人 现在 看 不 到 ,但 之 后 会 让 一 
个 或 两 个 玩家 看 到 的 牌 。 














好 多 网 站 都 能 让 你 玩 扑 克 牌 ,但 这 些 网 站 本 身 充当 了 受信 任 的 第 三 方 ， 由 他 们 来 
发 牌 或 将 牌 展示 给 各 个 玩家 的 浏览 右 。 
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在 没有 受信 任 的 第 三 方 的 情况 下 ,， 鲍 邦和 艾 莉 丝 还 能 玩 扑克 牌 吗 ?在 20 世 纪 70 年 
代 和 80 年 代 ， 密 码 学 家 设计 了 许多 种 通过 电话 或 网 络 进行 双人 或 多 人 牌 类 游戏 的 方 
案 ， 每 个 玩家 都 有 自己 的 私 钥 和 公 钥 ， 并 需要 对 加 密 的 信息 再 进行 一 次 加 密 。 























20 世 纪 80 年 代 和 9%0 年 代 , 密码 学 家 研发 出 了 非常 通用 的 技术 , 让 任意 需要 跟 受 信任 
对 手 玩 的 游戏 都 能 通过 互联 网 进行 , 即使 没有 受信 任 的 对 手 也 可 以 。 这些 方 法 既 用 到 了 
加 密 技 术 ,， 又 使 用 了 零 知识 证 明 。 这 些 通信 协议 相当 复杂 ， 而 且 很 少 被 实际 应 用 。 现 实 
中 人 们 要 么 依靠 受信 任 的 网 站 ， 要 么 会 采用 一 些 针对 某 个 特定 目的 而 设计 的 通信 协议 。 




















8.6 ”在 云 上 进行 加 密 计 算 





假如 艾 莉 丝 需要 对 敏感 数据 进行 计算 ， 而 鲍 勃 是 云 计 算 服务 的 提供 商 。 艾 莉 丝 可 
以 通过 鲍 勃 的 公 钥 把 数据 传送 给 鲍 勃 。 鲍 勃 解密 数据 ， 做 完 计算 ， 把 结果 用 艾 莉 丝 的 
公 钥 加 密 后 回 传 给 艾 莉 丝 。 如 果 艾 莉 丝 和 鲍 勃 使 用 的 公 钥 加 密 协 议 足 够 安全 ,没有 人 
可 以 从 中 得 知 艾 莉 丝 的 数据 。 如 果 艾 莉 丝 信任 鲍 勃 那 没 问题 ， 但 如 果 她 对 鲍 勃 不 够 信 
任 ， 想 让 数据 对 鲍 勃 也 是 保密 的 ， 还 能 进行 云 计算 吗 ? 








解决 这 个 问题 需要 使 用 所 谓 完全 同 态 (homomorphic ) 的 加 密 方法 。RSA 协 议 中 ， 
如 果 把 两 个 数 ( 如 28 和 45 ) 经 过 加 密 的 版 本 相 乘 ， 就 可 得 到 它们 的 乘积 1260 的 加 密 版 
本 。 不 需要 知道 原始 的 数字 ， 就 能 通过 加 密 数字 计算 其 乘积 的 加 密 版 本 。 另 一 方面 ， 
RSA 上 的 加 法 不 满足 这 个 条 件 。 人 们 不 知道 有 什么 方法 可 以 由 28 和 45 的 加 密 版 本 得 到 
其 和 73 的 加 密 版 本 。 











大 多 数 计算 可 以 用 数 之 间 的 和 与 积 来 表示 。 和 类 似 于 或 门 ， 积 类 似 于 与 门 ， 这 样 
就 能 用 和 与 积 来 构造 电路 。 完 全 同 态 的 加 密 方 法 允许 我 们 直接 用 加 密 后 的 数字 来 计算 
加 密 后 的 和 与 积 。 使 用 这 种 方法 可 以 从 加 密 的 输入 直接 得 到 加 密 的 和 输出， 不 需要 任何 
附加 的 通信 过 程 。 


艾 莉 丝 可 以 采用 完全 同 态 的 加 密 方 案 ， 把 加 密 过 的 数据 上 传 到 鲍 勃 的 计算 机 。 鲍 
勃 在 执行 艾 莉 丝 指 定 的 计算 时 ,不 需要 知道 艾 莉 丝 的 原始 数据 。 鲍 勃 得 到 的 计算 结果 
是 经 过 加 蜜 的 版 本 ,他 自己 无 法 解密 这 些 结果 ， 只 有 艾 莉 丝 能 在 下 载 之 后 用 自己 的 私 
钥 进行 解密 。 
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很 多 年 来 , 密码 学 家 都 无 法 实现 完全 同 态 加 密 , 很 多 人 曾 认 为 它 不 可 能 实现 。 2009 
4E, 斯坦福 大 学 的 研究 生 元 雷 格 * 金 特 里 发 现 了 一 个 实现 完全 同 态 加 密 的 方案 。 这 个 
方案 的 效率 还 无 法 达到 实用 要 求 , 但 可 以 肯定 的 是 , 它 开 启 了 全 新 的 可 能 性 之 门 ,不 
久 的 将 来 就 会 出 现 更 好 的 加 密 协议 。 


























8. ” 创 关 随机 性 


石头 剪刀 布 是 一 个 很 流行 的 小 游戏 ， 参 与 游戏 的 两 个 人 用 手势 比划 出 剪刀 、 石 头 
或 布 的 样子 。 




















A13: BERIBXR S97] , 于 是 出 石头 的 人 记 出 剪刀 的 人 。 剪刀 能 剪 碎 布 , 布 能 包 住 石 头 。 
如 果 两 人 出 同样 的 手势 ， 那 么 算 平 手 。 








如 何 来 选择 玩 石 头 剪刀 布 最 好 的 策略 ?” 如 果 你 能 比较 准确 地 预测 对 手 , 那 就 根据 
其 行动 来 决定 做 出 什么 手势 。 但 是 让 我 们 反 过 来 想 想 , 如 果 对 手 看 穿 了 你 的 思维 习惯 ， 
你 会 一 直 输 吗 ? 

















如 果 你 总 是 随机 选择 手势 就 不 会 。 你 等 概率 地 出 剪刀 、 石 头 和 布 ， 那 么 不 论 你 的 
对 手 做 什么 ， 你 总 会 有 三 分 之 一 的 时 间 遍 、 三 分 之 一 的 时 间 输 ， 以 及 三 分 之 一 的 时 间 
平局 。 话 虽 如 此 ， 人 类 很 难 做 出 完全 随机 的 选择 ， 这 才 使 得 在 多 次 进行 石头 剪刀 布 的 
游戏 时 有 真正 的 技巧 性 可 言 。 








剪刀 赢 布 








图 8-14 ”石头 剪刀 布 
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类 似 地 , 密码 学 也 要 求 有 随机 性 。 本 章 中 谈 到 的 每 一 个 加 密 方 法 都 涉及 随机 选择 ， 
以 让 信息 对 窃听 者 和 对 手 保密 。 如 果 数 字 不 是 完全 随机 的 ,那么 对 手 将 会 占 优 势 ， 甚 
至 对 于 一 次 性 密码 本 这 种 安全 的 加 密 方法 也 是 如 此 。 








计算 机 如 何 生成 随机 数 呢 ?” 计 算 机 不 会 抛 硬 币 ， 即 使 它 会 , 硬币 也 同样 遵循 物理 
法 则 ,不 能 实现 真正 的 随机 。 人 们 也 许 能 从 量子 效应 中 抽取 随机 性 , 但 目前 还 不 能 在 
日 常 计算 中 实际 大 量 使 用 这 种 方法 。 








人 们 抛 硬币 ， 掷 奶子 ， 洗 牌 或 转动 轮 盘 ， 都 是 为 了 创造 随机 性 。 所 有 这 些 操作 都 
直接 遵循 物理 法 则 ， 赌 场 完全 不 会 有 赔钱 的 风险 。 轮 盘 赌 中 小 球 和 转盘 的 复杂 交互 作 
用 , 使 得 预测 某 次 转动 的 结果 在 计算 上 几乎 是 不 可 能 实现 的 , 一 般 人 几乎 无 法 将 轮 盘 
赌 结果 的 分 布 和 完全 的 随机 行为 区 分 开 来 。 






































计算 机 也 采用 了 这 样 的 方法 。 它 并 不 直接 拥有 完全 随机 的 比特 ， 而 是 通过 执行 某 
些 结果 难以 预测 的 操作 来 生成 “ 僵 随 机 数 ”。 密 码 学 和 随机 数 生成 之 间 有 直接 的 联系 。 
经 过 加 密 的 消息 在 没有 密 钥 的 对 手 看 来 应 该 是 随机 的 。 许多 加 密 技术 可 以 被 改造 为 很 
好 的 随机 数 生成 器 。 




















你 的 计算 机 基本 不 用 这 些 系 统 来 生成 伪 随 机 数 ， 而 是 用 一 些 更 为 高 效 的 系统 ,这 
些 系统 通常 效果 不 错 , 但 在 理论 上 不 能 保证 安全 。 如 何在 更 少 的 计算 时 间 和 更 高 的 伪 
随机 性 之 间 权 衡 是 一 个 两 难 的 问题 。 











伪 随 机 数 生成 器 只 在 问题 复杂 到 一 定 程 度 时 才 有 效 。 如 果 P= NP , 那 每 一 个 计算 
上 高 效 的 过 程 都 能 在 某 种 程度 上 被 逆转 , 这样， 生成 计算 上 随机 的 抛 硬 币 事件 就 很 难 
了 ， 甚 至 是 不 可 能 的 。 石 头 剪刀 布 在 美妙 世界 将 不 再 是 一 个 靠 运气 的 游戏 。 








8.8 ”持续 的 挑战 





我 们 目前 使 用 的 是 基于 因数 分 解 等 NP 问题 的 公 钥 加 密 系统 。 艾 莉 丝 很 容易 就 能 
成 一 个 只 有 她 知道 因子 且 很 难 被 因数 分 解 的 大 数 ， 只 要 随机 选择 两 个 大 的 质数 ,把 它 
们 相 乘 就 可 以 了 。 











人 们 还 不 知道 因数 分 解 是 否 为 NP 完全 问题 ， 但 倾向 认为 不 是 。 即 使 它 是 NP 完全 
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的 , P#NP 也 只 是 意味 着 存在 某 些 难以 因数 分 解 的 大 数 。 随 机 选择 的 数字 仍然 有 可 能 


容易 被 因数 分 解 。 








现代 密码 学 构建 在 NP 完全 问题 的 困难 性 以 及 PNP 的 假设 之 上 ， 





前 面临 的 心腹 之 患 。 











20 世 纪 70 年 代 迪 菲 和 赫 尔 曼 的 工作 彻底 改变 了 密码 学 , 让 我 们 能 









































这 是 该 学 科目 


[ 接 基于 求解 某 





些 问题 的 困难 程度 来 构造 加 密 协议 。 纵 横 填 字 高 手 、 国 际 象棋 大 师 和 聪明 的 数学 家 再 





也 不 能 找到 直接 破解 这 些 密码 的 方法 了 。 





而 猫 鼠 游戏 并 没有 因此 终止 。 既 然 不 能 直接 地 破解 密码 ， 黑客 转 而 攻击 其 他 的 薄 




















弱 环 节 。 艾 和 莉 丝 和 鲍 勃 可 能 没有 在 通信 协议 中 使 用 很 好 的 随机 数 。 黑 客 可 能 会 利用 艾 
莉 丝 使 用 的 浏览 咒 或 操作 系统 的 设计 缺陷 来 入 侵 她 的 计算 机 。 艾 莉 丝 可 能 被 蒙骗 ,将 
私 钥 告诉 其 他 人 。 艾 莉 丝 选择 的 密码 可 能 不 够 强壮 ， 从 而 让 黑客 有 了 可 乘 之 机 。 























除了 通常 能 看 到 和 想到 的 通信 数据 之 外 , 黑客 还 能 利用 一 些 其 他 的 信息 来 破解 密 
码 。 比 如 计算 花费 的 时 间 与 编码 的 消息 也 许 是 相关 的 ， 黑 客 可 以 利用 这 一 点 。 黑 客 还 























可 能 会 破坏 系统 的 一 部 分 ， 比 如 把 智能 卡 扔 进 微波 炉 加 热 ， 这样 做 有 可 能 使 受 损 的 计 























算 芯 片 不 再 保障 数据 的 安全 性 。 











人 们 也 许 会 发 明理 论 上 牢 不 可 破 的 加 密 方法 , 但 基本 上 永远 都 不 可 能 实现 绝对 不 


会 泄密 的 保密 系统 。 


1982 年 ， 诺 贝尔 奖 得 主 物理 学 家 理 查 德 ， 
电子 计算 机 对 量子 物理 系统 进行 简单 的 仿真 。 











费 曼 发 现 ， 不 存在 简单 的 方法 可 以 利用 
他 把 这 个 问题 转化 为 一 个 机 会 ,提议 也 


许可 以 研发 一 种 基于 量子 力学 的 计算 设备 ， 其 计算 效率 比 传统 的 计算 机 更 高 。 在 接 下 


来 的 十 年 ， 计 算 机 科学 家 和 物理 





学 家 经 过 合作 ， 在 更 





计算 机 更 快 地 解决 某 些 问题 ,例如 因数 分 解 。 至 于 是 否 能 





E 论 上 证 明了 量子 计算 机 能 比 普通 


建造 出 真正 可 用 的 大 型 或 中 





等 规模 的 量子 计算 机 ， 并 且 了 解 这 类 计算 机 到 底 能 做 什么 ,不 能 做 什么 ,仍然 是 意义 
非凡 的 重大 挑战 。 本 章 我 们 将 探讨 量子 计算 的 力量 ， 以 及 与 之 相关 的 量子 密码 学 和 量 
子 隐形 传输 (quantum teleportation )。 





9.1 量子 录像 机 




















汤姆 是 波士顿 人 ， 很 自然 地 ， 他 也 是 波士顿 红 袜 队 的 球迷 。 有 一 天 在 汤姆 上 班 的 
时 候 , 纽约 洋基 队 客 场 对 战 波士顿 ,他 刻意 避免 读 到 任何 关于 比赛 的 消息 。 下 班 回 家 
后 ， 他 订 了 一 些 披萨 饼 ， 打 开 录 像 机 ， 开 始 观赏 几 小 时 前 就 结束 的 这 场 比赛 。 第 9 局 
末 ,， 红 袜 队 在 二 人 又 和 三 又 有人， 两 人 出 局 ， 一 人 被 夹 杀 。 此 时 波士顿 的 强力 击 球 手 布 
莱恩: 哈 默 走 上 本 人 垒 板 ， 汤姆 十 分 希望 哈 默 能 击 中 。 汤 姆 觉得 自己 有 点 反应 过 度 了 ， 

















毕竟 比赛 早 就 结束 了 ， 哈 默 要 么 击 中 了 ， 要 么 没 击 中 。 但 是 汤姆 不 知道 是 盟 























个 结果 。 


在 汤姆 看 来 ， 比 赛 的 结果 还 是 未 被 确定 的 ， 实 际 的 结果 介 于 输 和 赢 之 间 ， 并 且 很 快 就 








会 向 他 揭 开 谜底 。 


汤姆 的 真实 取决 于 他 的 观测 。 从 汤姆 的 观点 来 看 ， 只 要 他 没有 观看 到 最 后 一 刻 ， 
比赛 就 还 没有 结束 , 胜 者 还 未 被 确定 。 在 最 后 一 刻 之 前 ,比赛 处 在 一 种 奇怪 的 状态 中 ， 
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介 于 红 袜 队 辜 和 输 之 间 。 

















洋基 队 的 铁杆 球迷 苏 姗 也 把 同一 场 比赛 用 录像 机 录 了 下 来 , 并且 和 汤姆 在 同一 时 间 
分 别 观看 自己 的 录像 。 苏 如 和 汤姆 一 样 , 不 知道 哈 默 是 否 能 击 中 , 如 果 击 中 那 洋基 队 就 
输 了 。 苏 姗 脑海 中 的 比赛 也 是 不 确定 的 ， 是 一 个 随机 性 事件 ， 直 到 她 看 完整 场 比赛 。 




















苏 姗 和 汤姆 在 同一 时 刻 、 相 隔 200 英 里 的 两 个 地 点 观察 两 个 随机 事件 。 然 而 ， 他 
们 将 看 到 一 致 的 结果 : 两 个 人 要 么 都 观测 到 哈 默 击 打 成 功 , 要 么 都 观测 到 他 击 打 失败 。 
不 可 能 汤姆 看 到 哈 默 击 中 了 球 而 苏 姗 看 到 哈 默 被 三 振 出 局 。 两 个 人 都 不 知道 结果 , 但 
都 确信 看 到 的 比赛 结果 是 一 样 的 。 记 录 在 苏 姗 和 汤姆 的 录像 机 上 的 结果 ， 以 某 种 方式 
彼此 纠缠 在 一 起 。 























这 和 量子 计算 有 什么 关系 ? 传统 计算 机 最 基本 的 元 素 是 比特 (bit, binary digit 的 
简写 )， 它 只 能 取 两 个 值 中 的 一 个 ， 如 赢 或 输 、 真 或 假 。 而 量子 计算 机 的 基本 元 素 叫 
量子 比特 (quantumbit )。 和 只 能 取 两 个 值 之 一 的 比特 不 同 , 量子 比特 的 取 值 能 介 于 两 
个 值 之 间 。 








记录 在 录像 带 上 的 棒球 比赛 并 不 是 真 的 量子 比特 ,但 是 它们 有 一 些 共同 的 属性 。 
汤姆 看 球赛 时 ， 直 到 比赛 结束 ,结果 都 是 不 确定 的 。 而 从 他 观测 到 比赛 结束 的 那 一 刻 
起 ， 结 果 就 确定 了 ， 红 袜 队 不 是 局 了 就 是 输 了 ,不 再 介 于 两 者 之 间 。 类 似 地 ， 从 量子 
比特 被 观测 到 的 那 一 刻 起 ， 它 就 变 成 了 一 个 传统 的 比特 ， 只 能 取 两 个 值 之 一 ， 而 不 是 
介 于 两 个 值 之 间 。 









































量子 比特 可 以 互相 纠缠 ， 就 像 汤 姆 和 苏 姗 的 录像 带 那 样 。 让 两 个 量子 比特 互相 纠 
缠 ， 这 样 它们 在 被 观测 到 的 那 一 刻 就 总 能 给 出 相同 的 管 案 。 











不 过 二 者 的 相似 性 就 到 此 为 止 了 。 量 子 比特 能 以 复杂 得 多 的 方式 互相 纠缠 ， 而 这 
些 纠缠 态 可 被 操控 ， 从 而 形成 计算 能 


比赛 的 结果 是 一 个 简单 的 概率 ， 可 以 在 一 条 简单 的 直线 上 取 任 意 值 。 











波士顿 输 








图 9-1 波士顿 

















第 9 章 
五 角 星 所 处 的 位 置 代表 波士顿 有 30% 的 概率 会 语 。 汤 姆 看 完了 比赛 ， 五 角 星 要 么 
左 移 到 尽头 ， 要 么 右 移 到 尽头 ， 至 于 向 哪 边 移动 则 取决 于 比赛 结果 。 
量子 比特 则 可 在 一 个 圆圈 上 取 值 。 
假 假 
真 





图 9-2 量子 比特 








这 张 图 里 的 五 角 星 在 二 维 平面 中 的 坐标 是 (0.55 真 , 0.84 假 )。 量 子 比特 也 可 以 取 负 
值 。 笑 脸 代表 的 量子 比特 取 值 为 (-0.71 真 , -0.71 假 )。 量 子 计算 机 能 以 可 控 的 方式 旋转 








或 翻转 这 个 圆圈 。 
一 个 量子 比特 可 用 一 个 二 维 的 圆圈 来 表示 。 两 个 量子 比特 则 需要 用 一 个 四 维 版 本 
的 圆圈 来 表示 其 状态 ， 很 难 在 这 里 画 出 来 ， 甚 至 难以 想象 。30 个 量子 比特 则 需要 超过 








] 万 亿 个 维度 。 
这 启发 人 们 可 以 用 量子 计算 机 的 方法 解决 NP 问 题 。 想 想 从 2 万 敌 友 国 居民 中 找 出 


50 人 的 团 的 问题 。 我 们 能 用 大 概 500 个 量子 比特 表示 出 所 有 可 能 的 50 人 的 集合 。 然 后 
所 有 的 集合 ,并 通过 适当 的 旋转 和 翻转 操作 标记 出 其 中 能 够 组 成 


























可 以 同时 并 行 地 处 至 
团 的 那些 集合 。 
子 态 ”， 即 大 概 3 x 109. (3 后 面 跟 150 个 0 ) 组 敌 友 国 居民 
这 些 团 从 量子 态 中 抽 


用 茶 种 方式 很 快 地 把 


€€ E, 
里 








我 们 现在 有 了 一 个 

的 组 合 状态 ， 其 中 某 些 被 标记 为 团 。 如 果 能 

取出 来 , 我 们 就 能 用 量子 方法 快速 解决 团 问题 以 及 每 一 个 其 他 的 NP 问 题 。 当 我 们 观测 
只 能 看 到 一 个 结 








这 个 量子 状态 的 时 候 〈 就 好 比 看 到 录像 带 上 比赛 的 结尾 )， 我 们 

即 敌 友 国 中 的 一 群 人 ， 而 很 有 可 能 这 群 人 不 会 组 成 一 个 团 。 
我 们 需要 某 种 方式 ， 让 组 成 团 的 人 群集 合 脱颖而出 ， 从 而 更 有 可 能 被 观测 到 。 这 

可 以 用 量子 操作 来 实现 。 最 策 的 方法 将 使 用 和 集合 的 个 数 相等 次 数 的 量子 操作 ， 即 大 
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TES x 10” 次 的 量子 操作 ， 完 全 没有 体现 使 用 量子 计算 的 优势 。1996 年 ， 在 新 泽 西 州 由 
尔 实验 室 工作 的 洛 夫 ' 格 罗 佛 发 明了 一 种 更 高 明 的 量子 算法 ,“ 仅 仅 ”使 用 2 x 10 次 的 
量子 操作 。 即 使 我 们 每 秒 做 1 万 亿 次 量子 操作 , 所 需 时 间 也 大 致 是 当前 宇宙 年 龄 的 5 倍 。 






























































有 某 些 证 据 表明 格 罗 佛 的 算法 是 使 用 量子 计算 机 来 求解 NP 完 全 问题 所 能 达到 的 
最 好 结果 , 所 以 P= NP 的 量子 版 本 也 不 太 可 能 成 立 。 即 使 物理 学 家 们 成 功 造 出 了 量子 
计算 机 ， 它 还 是 无 法 解决 我 们 面临 的 最 难 的 问题 。 

















这 并 不 意味 着 量子 计算 机 就 没有 用 了 。 它 能 对 纳米 级 别 的 物理 系统 有 效 地 进行 复 
杂 的 仿真 ， 这 将 有 助 于 揭 开 和 宇宙 的 一 些 未 解 之 这 。 量 子 计算 机 还 能 求解 某 些 人 们 无 法 
用 传统 计算 机 有 效 解决 的 NP 问题 。 











1994 年 ， 贝 尔 实验 室 的 另 一 名 研究 人 员 彼 得 肖 尔 意识 到 ， 量 子 计算 机 能 对 数字 
进行 因数 分 解 ， 例 如 对 于 数字 16 461 679 220 973 794 359， 找 到 两 个 数 5 754 853 343 
和 2 860 486 313, ， 并 有 5 754 853 343x 2 860 486 313 = 16 461 679 220 973 794 359。 他 
的 算法 工作 在 快速 的 量子 计算 机 上 ， 对 几 百 位 甚至 几 千 位 的 大 数 都 有 效 。 搜 索 一 个 数 
的 因子 问题 有 着 良好 的 代数 结构 ， 可 被 量子 计算 机 利用 。 尽 管 我 们 认为 因数 分 解 对 于 
今天 的 计算 机 是 很 难 的 问题 , 量子 计算 机 则 能 够 借 此 克服 这 些 困 难 , 分 解 很 大 的 数字 。 
而 NP 完全 问题 则 缺乏 这 种 良好 的 代数 结构 , 故 肖 尔 的 算法 对 通用 的 NP 问题 是 无 效 的 。 




















当然 ,我 们 能 真正 使 用 格 罗 佛 或 肖 尔 的 算法 的 前 提 是 : 有 一 个 能 工作 的 量子 计算 
机 。 为 解决 今天 的 机 器 无 法 解决 的 规模 可 观 的 问题 ,我们 至 少 需 要 上 万 个 量子 比特 彼 
此 纠 强 ， 并 在 几 秒 的 时 间 内 是 可 控 的 。 可 惜 的 是 ， 量子 纠缠 态 十 分 脆弱 。 量 子 系统 和 
外 界 环境 的 任何 交互 作用 都 可 能 引起 一 次 “观测 ”， 导 致 某 些 纠缠 态 的 丧失 ， 这 对 于 
精密 的 量子 计算 是 不 可 挽回 的 灾难 。 




































































甚至 对 于 两 个 量子 比特 , 目前 物理 学 家 还 不 能 使 其 达到 完美 或 接近 完美 的 量子 纠 
E 态 。 计 算 机 科学 家 采用 所 谓 量子 纠 错 的 方法 来 设计 算法 ， 以 处 理 中 等 规模 的 量子 纠 
1 使 如 此 ， 我 们 不 知道 如 何在 超过 5 个 量子 比特 之 间 创 造 出 显著 数量 的 纠缠 态 。 

能 存在 某 些 自然 界 的 基本 法 则 , 阻止 量子 之 间 在 一 段 足够 长 的 时 间 内 处 于 显著 的 纠 
态 ， 也 可 能 这 只 是 一 个 环 手 的 工程 问题 。 我 们 还 是 让 物理 学 家 来 解决 这 个 问题 吧 。 
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还 有 其 他 利用 量子 效应 来 进行 计算 的 方法 ， 如 量子 绝热 系统 ， 或 量子 退火 ， 而 它 
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们 也 分 别 有 自 身 的 技术 和 计算 局 限 性 ,一 个 叫 D-Wave 的 公司 宣称 建造 了 基于 这 些 技术 
的 机 器 ， 但 这 些 机 咒 的 计算 能 力 能 和 否 超 过 人 们 的 桌面 电脑 ， 还 有 待 评估 。 














即使 我 们 发 现 了 建造 真正 的 量子 计算 机 的 方法 , 这 些 机 顺 仍 然 是 为 特殊 用 途 而 建造 
的 , 如 因数 分 解 或 者 量子 系统 的 仿真 。 它 们 也 许 有 助 于 破解 密码 ,以 及 加 深入 们 对 宇宙 
的 本 质 的 了 解 ， 但 不 太 可 能 用 它们 来 求解 NP 完全 问题 ,或 加 快 电子 表格 的 运行 速度 。 








92 ”量子 密码 学 


我 们 第 8 章 中 讨论 的 大 部 分 密码 学 工具 的 安全 性 都 依赖 于 一 个 假设 ， 即 因数 分 解 
是 一 个 计算 上 困难 的 问题 。 任 何人 只 要 口袋 里 装着 量子 计算 机 ， 就 能 用 肖 尔 的 算法 把 
密 钥 分 解 因数 进而 破解 这 些 密 码 。 虽 然 现在 还 没有 装 在 口袋 里 的 量子 计算 机 , 但 将 来 
有 可 能 出 现 。 密码 学 家 可 以 通过 设计 基于 其 他 困难 问题 的 通信 协议 来 设法 绕 过 量子 攻 
击 ， 而 这 些 问 题 必须 缺乏 量子 计算 机 能 利用 的 良好 代数 结构 。 量 子 学 术 界 则 为 我 们 提 
供 了 另 一 个 解决 方案 ， 即 基于 量子 力学 的 密码 学 。 




















我 们 对 于 复制 计算 机 数据 这 件 事 已 经 习以为常 了 。 差 不 多 每 一 个 计算 平台 都 会 提 
供 复制 和 粘贴 功能 。 我 们 可 以 把 文件 的 多 个 副本 放 在 不 同 目录 下 或 不 同 的 机 器 上 。 我 
们 能 把 数据 备份 到 硬盘 或 是 “云端 "。 这 带 来 的 麻烦 是 ,信息 的 副本 太 多 了 ， 以 至 于 
很 难 彻底 删除 某 些 个 人 文件 或 电子 邮件 ， 并 确保 其 他 的 地 方 不 留 下 相应 的 副本 。 





















































与 之 相反 ,量子 比特 不 能 被 复制 。 复制 一 个 量子 比特 就 需要 观察 它 ， 而 无 论 以 何 
种 受 限 的 方式 来 观察 ,都 将 导致 量子 比特 转变 成 普通 的 比特 。 乔 治 想 把 一 个 量子 比特 
递送 给 哈 利 。 如 采 埃 里 克 在 途中 试图 复制 或 读 取 ， 那 个 比特 将 变 成 一 个 普通 的 比特 。 
当然 这 本 身 并 不 构成 一 个 发 送 秘密 消息 的 方式 ， 毕 竞 消 息 接收 者 哈 利 也 必须 要 读 取 这 
个 比特 ， 并 导致 它 的 性 质 改 变 。 
































1979 年 , 来 自 蒙 特 利 尔 大 学 的 吉尔 斯 布 拉 萨 德 在 波多 黎 各 参加 了 IEEE 计 算 机 科 
学 基础 会 议 ( Foundations of Computer Science conference )， 该 会 议 是 理论 计算 机 科学 
界 的 主要 会 议 之 一 。IBM 的 查理 * 贝 内 特 找 到 了 在 海滩 游泳 的 吉尔 斯 ， 这 次 海边 相 会 
开启 了 两 位 科学 家 一 段 令 人 惊叹 的 科研 合作 , 其 工作 成 果 包 括 使 用 量子 比特 来 创造 理 
论 上 不 可 破译 的 密码 的 方法 。 贝 内 特 和 布 拉 萨 德 发 明 的 方法 通过 混合 使 用 经 典 和 量子 
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加 密 技术 ， 既 能 让 乔治 和 哈 利 成 功 地 传输 一 把 密 钥 以 供 将 来 加 密 消息 ， 又 能 侦 测 到 该 
密 钥 是 否 已 被 监听 者 截获 ， 那 样 的 话 他 们 可 以 再 试 一 次 。 

















这 个 通信 协议 也 有 局 限 性 。 为 处 理 可 能 出 现 的 小 错误 ,， 不仅 要 增加 所 需 的 量子 比 
特 的 个 数 ， 也 让 监听 者 埃 丝 特有 机 可 乘 ， 有 可 能 不 被 察觉 地 做 些 手 脚 。 人 们 又 研发 了 
一 系列 更 复杂 的 通信 协议 来 应 对 这 些 新 问题 。 























和 量子 计算 不 一 样 ， 贝 内 特 - 布 拉萨 德 协议 不 需要 量子 达到 彼此 纠缠 的 状态 ， 而 
且 已 经 实现 了 可 以 实际 运转 的 中 等 规模 的 量子 加 密 系 统 。 洛 斯 阿拉 莫 斯 国 家 实验 室 的 
研究 者 已 成 功 地 通过 148 千 米 长 的 光缆 发 送 消息 。 还 有 人 通过 大 气 在 加 那 利 群岛 的 两 
个 岛屿 间 发 送 了 信息 ， 距 离 也 将 近 145 千 米 。 在 不 远 的 将 来 ,我们 将 能 用 卫星 来 发 送 
使 用 量子 技术 的 不 可 破译 的 密码 。 


















































那 我 们 为 什么 不 为 所 有 的 秘密 通信 需求 应 用 量子 密码 学 呢 ? 量子 密码 技术 仍 处 
于 实验 期 ,十 分 晶 贵 、 带 宽 有 限 而 且 容易 出 错 。 密 码 系 统 的 漏洞 通常 不 在 于 使 用 的 加 
密 方 案 能 够 被 破解 ， 而 在 于 实际 的 执行 操作 中 的 薄弱 环节 。 如 果 量 子 通信 协议 投入 实 
际 应 用 ， 其 操作 安全 性 很 可 能 和 经 典 方法 一 样 差 ， 甚至 有 可 能 更 差 。 男 外 ， 目 前 没有 
已 知 的 方法 能 让 量子 密码 通过 互联 网 传输 ,因为 信息 通过 互联 网 从 源头 传输 到 目的 地 
的 过 程 中 要 经 过 多 次 路 由 的 转发 。 最 重要 的 是 ,我 们 很 可 能 无 法 在 未 来 较 短 时 期 内 看 
到 能 解决 因数 分 解 问题 的 计算 机 ,无 论 是 量子 计算 机 或 是 其 他 的 计算 机 。 目 前 所 用 的 
密码 在 很 长 一 段 时 期 内 都 将 是 安全 的 。 
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1996 年 2 月 的 《科学 美国 人 》 林 志 在 封 二 刊登 了 IBM 的 广告 ， 宣 传 该 公司 的 研究 
新 进展 。 


很 多 年 来 她 和 住 在 大 阪 的 朋友 分 享 食谱 。 她 向 他 展示 了 几 百 种 使 用 红 辣 
椒 的 方式 。 他 则 分 享 了 寿 喜 烧 的 独家 秘方 。 有 一 天 ， 玛 格 丽 特 女 士 给 小 泽 先 
生发 了 一 封 电 邮 ， 里 面 说 :“ 做 好 准备 ， 我 给 你 心灵 传输 (teleport) 了 一 份 
炖 牛肉 。” 玛 格 丽 特 女 士 对 技术 的 要 求 稍 微 有 点 超前 ， 但 我 们 一 直 在 为 实现 
她 的 愿望 而 努力 。 来 自 IBM 的 科学 家 和 他 的 同事 们 发 现 了 一 种 方法 ， 能 将 一 
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个 物体 原 地 分 解 、 再 在 另 一 个 地 点 毫发 无 伤 地 重 现 它 。 听 起 来 像 变 魔 术 ， 但 
是 他 们 取得 的 突破 性 进展 将 影响 到 科技 生活 的 方方面面 ， 从 研发 未 来 的 计算 
机 ， 到 拓展 人 类 对 宇宙 的 认 知 。 真 是 一 群 聪明 的 家 伙 ! 但 他 们 中 还 没有 一 个 


人 能 把 肉 馅 塞 进 卷心菜 里 。 





图 9-3 ” IBM 的 广告 。 由 [BM 公司 提供 


广告 中 标榜 的 技术 是 怎么 回 事 ? 与 其 说 它 和 炖 牛肉 有 关系 , 不 如 说 和 量子 比特 有 
关系 。 而 量子 比特 真 的 可 以 原 地 分 解 ， 再 在 另 一 个 地 点 重 现 ， 就 好 像 变 魔术 一 样 。 广 
告 中 提 到 的 研究 人 员 就 是 1993 年 在 IBM 工 作 的 科学 家 查理 - 贝 内 特 和 他 的 同事 们 ,其 中 
包括 吉尔 斯 : 布 拉 萨 德 。 为 我 们 带 来 量子 加 密 技术 的 这 群 人 ， 也 发 明了 量子 隐形 传输 。 






























































假如 阿 瑟 想 把 一 个 量子 比特 传输 给 哈 瑞 特 ， 该 如 何 做 呢 ? 
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图 9-4 量子 比特 
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阿 瑟 可 以 选择 用 联邦 快递 来 寄 送 这 个 量子 比特 , 但 是 如 果 海 关 人 员 想 查看 包 庄 内 
容 ， 就 会 毁 掉 这 个 量子 比特 ， 让 它 变 成 只 能 取 真 假 二 值 之 一 的 普通 比特 。 即 使 阿 瑟 十 
分 小 心地 亲自 运送 这 个 量子 比特 , 他 也 不 可 能 完全 避免 它 在 与 外 界 环 境 的 相互 作用 中 
被 损坏 。 














阿 蕊 也 可 以 发 送 这 个 量子 比特 的 描述 信息 (-0.55 真 , 0.84 假 ), 哈 瑞 特 根据 描述 重建 
一 个 完全 相同 的 量子 比特 。 但 如 果 阿 瑟 只 有 量子 比特 本 身 ， 他 无 法 对 其 准确 的 描述 做 
出 判断 ， 因 为 任何 试图 测度 量子 比特 的 行为 都 将 导致 它 志 缩 为 真 或 假 二 值 之 一 。 























贝 内 特 和 同事 们 为 阿 瑟 向 哈 瑞 特 传输 量子 比特 提供 了 一 种 方法 ， 但 有 一 个 缺点 。 
阿 瑟 和 哈 瑞 特需 要 事先 准备 一 些 彼此 纠缠 的 量子 比特 。 














图 中 带 心 形 的 量子 比特 处 于 纠缠 状态 ， 分 别 为 阿 基 和 哈 瑞 特 持 有 。 如 果 阿 琶 观 测 
他 的 量子 比特 ， 他 会 等 概率 地 看 到 “ 真 ”或 “ 假 ”。 但 奉 阿 蕊 看 到 的 是 “ 真 *， 那 哈 瑞 
特 看 到 的 必然 是 “ 真 "*， 如 果 他 看 到 了 “ 假 *"， 那 她 看 到 的 也 是 “ 假 *"， 这 和 本 章 前 面 
介绍 的 棒球 比赛 是 类 似 的 。 
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图 9-5 纠缠 
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阿 巷 现在 有 两 个 量子 比特 , 标 有 五 角 星 的 用 来 传输 ， 标 有 心 形 的 和 哈 瑞 特 的 量子 
比特 处 于 纠缠 态 。 之 前 提 到 过 ， 这 两 个 量子 的 组 合 态 在 四 维 空 间 表现 为 一 个 球体 。 阿 
巧 在 不 观察 量子 比特 的 情况 下 小 心地 旋转 这 个 四 维 球 。 然 后 阿 瑟 观测 这 两 个 量子 比 
寺 ， 得 到 两 个 普通 的 比特 ( 0 或 1 )。 

















阿 巷 把 这 两 个 普通 的 比特 传送 给 哈 瑞 特 。 其 中 一 个 比特 告诉 哈 瑞 特 是 否 要 旋转 她 
的 量子 比特 ， 另 一 个 则 表示 是 否 要 翻转 它 。 哈 瑞 特 根据 指令 进行 相应 的 操作 。 接 着 轻 
吹 一 口气 ， 大 喊 一 声 “ 变 !” 袖 子 里 什么 部 没 藏 ! 突然 ， 哈 瑞 特 就 得 到 了 阿 讼 原来 的 
那个 量子 比特 。 令 人 震惊 的 是 ， 这 一 切 都 是 真 的 。 









































阿 巷 的 两 个 量子 比特 发 生 了 什么 ”它们 在 被 观测 到 的 那 一 刻 就 毁灭 了 。 否 则 ， 阿 
蕊 将 制造 出 量子 比特 的 副本 ， 这 是 量子 力学 法 则 所 禁止 的 。 
当 阿 瑟 操 作 和 测量 他 的 量子 比特 时 ， 哈 珊 特 的 比特 未 受 影响 。 阿 蕊 不 能 通过 对 自 


己 的 量子 比特 的 操作 而 影响 到 哈 瑞 特 的 量子 比特 , 否则 阿 蕊 就 有 了 和 哈 瑞 特 通信 的 方 
法 ， 这 种 信息 传递 的 速度 比 光速 还 快 ， 这 在 物理 学 上 是 不 可 能 的 。 












































当 哈 瑞 特 接收 到 阿 琶 传 来 的 两 个 比特 时 , 这 个 信息 能 让 她 把 自己 的 量子 比特 看 做 
阿 登 原来 的 量子 比特 经 过 量子 操作 后 的 版 本 。 这 两 个 普通 比特 准确 地 告诉 了 哈 瑞 特 要 
如 何 逆转 这 些 操作 , 才能 恢复 阿 世 原来 的 那个 量子 比特 。 哈 瑞 特 无 法 检测 阿 瑟 的 操作 ， 
但 随 着 阿 瑟 传送 过 来 的 两 个 普通 比特 , 一 个 完好 无 损 的 量子 比特 就 像 变 魔术 似 的 被 传 
输 过 来 了 。 





























假 
图 9-6 
怎么 把 这 一 切 和 炖 牛肉 或 者 《星际 迷航 》 中 那些 厉害 的 传送 器 联系 在 一 起 ?假如 








我 想 用 量子 隐形 传输 从 芝加哥 到 东京 。 某 个 公司 会 为 我 准备 一 大 堆 处 于 纠缠 态 的 量 
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子 ， 把 其 中 的 一 半 小 心地 运送 到 芝加哥 ， 必 一 半 运 送 到 东京 。 然 后 我 在 芝加哥 的 一 个 
小 房间 里 和 数量 多 到 足够 描述 我 的 量子 比特 待 在 一 起 ， 在 某 个 高 维 空间 被 旋转 ,然后 
经 过 测量 变 成 经 典 的 比特 。 这 些 比特 被 传送 到 该 公司 的 东京 分 支 机 构 ， 然 后 那里 的 人 
们 在 一 个 小 房间 里 以 恰当 的 方式 旋转 男 一 些 量子 比特 ， 打 开房 门 ， 我 就 出 现 了 。 酷 ! 














那 堆 彼此 纠缠 的 量子 就 这 样 被 消耗 了 。 要 传送 别人 或 者 把 我 传 回去 就 需要 一 堆 新 
的 处 于 纠缠 态 的 量子 比特 。 其 实 道理 和 航空 燃油 差不多 。 我 从 东京 坐 飞 机 回 家 ， 不 可 
能 重新 使 用 那些 在 来 东京 的 航班 上 消耗 的 燃油 。 




















更 令 人 担心 的 问题 是 如 何 让 那些 描述 我 的 海量 量子 〈 规模 可 能 达到 3 个 10 亿 相 乘 
的 数量 级 ， 基 本 上 相当 于 构成 人 体 的 原子 数量 ) 保持 在 完全 的 纠缠 状态 ,这 可 能 还 严 
重 低估 了 所 需 的 量子 比特 数量 。 即 使 有 极 小 部 分 的 量子 和 外 界 环 境 发 生 轻 微 作用 而 未 
失 了 纠缠 态 ， 从 男 一 头 出 现 的 我 就 很 可 能 被 慌 形 ， 其 至 变 成 一 团 死 肉 。 所 以 你 先 走 ， 
我 宁愿 慢 一 点 ， 消 耗 一 些 航空 燃油 ， 咱 们 东京 见 。 











94 ”量子 的 未 来 











有 些 研究 者 认为 应 该 从 量子 角度 重新 审视 所 有 的 计算 问题 。 即 使 量子 计算 机 不 能 
解决 NP 完全 问题 , 它 对 量子 世界 的 仿真 也 将 极 大 促进 人 类 对 物质 、 宇 宙 帮 至 人 类 大 脑 
的 认 知 ， 从 而 推动 科技 的 进步 ， 取 得 今天 所 无 法 想象 的 成 就 。 














还 有 人 看 到 , 量子 研究 从 20 世 纪 90 年 代 中 期 开始 在 算法 和 硬件 两 个 方面 的 进展 都 
十 分 缓慢 ， 据 此 怀疑 能 和 否 看 到 量子 在 计算 设备 中 起 到 关键 性 作用 的 那 一 天 。 如 果 缺 乏 
革命 性 的 进展 ， 量 子 计算 技术 在 未 来 一 段 时 期 内 仍 将 停留 在 科幻 作品 中 。 









































如 果 量 子 不 是 计算 领域 的 下 一 个 浪潮 , 那 什么 是 呢 ? 有 哪些 巨大 的 计算 挑战 在 前 
方 等 待 着 我 们 ?” 且 待 下 章 分 解 。 








X g 10s 小 
Kk 来 


我 本 人 对 P/NP 问 题 得 到 解决 的 前 景 持 翡 观 态度 : 我 认为 PNP ， 而 且 此 生 都 看 
不 到 它 的 证 明 。 我 们 不 会 见证 第 2 章 中 美妙 世界 的 到 来 ,但 是 也 不 能 排除 其 可 能 1 
我 认为 PNP 问题 在 未 来 的 几 个 世纪 内 仍 将 是 一 个 未 解 之 谜 。 

P/NP 问 题 不 仅仅 是 一 个 数学 上 的 异类 。 虽然 我 们 不 能 直接 解决 它 , 但 研究 它 的 过 
程 赋 予 了 我 们 一 种 通用 的 框架 ， 有 助 于 思考 如 何 应 对 从 实际 需求 中 产生 的 那些 困难 的 
问题 。 今 天 人 们 在 计算 学 方面 面临 哪些 重大 挑战 ? 

口 并 行 计算 : 曾经 每 过 18 到 24 个 月 , 计算 机 的 计算 速度 就 提高 一 倍 , 但 现在 我 们 
正在 触及 物理 极限 , 将 来 很 难 制造 出 比 现 在 快 得 多 的 处 理 器 。 另 一 方面 , 计算 
机 正在 横向 扩张 , 可 以 让 多 个 处 理 器 一 起 工作 , 不 论 是 在 同一 块 芯片 上 , 还 是 
在 云端 。 如 何 调整 我 们 的 算法 ， 以 适应 这 个 日 趋 并 行 化 的 世界 呢 ? 

a 大 数据 : 从 互联 网 到 科学 实验 再 到 仿真 研究 ， 我 们 每 天 都 在 生成 海量 的 数据 。 

如 何 试图 理解 、 感 受 、 学 习 如 此 庞杂 的 信息 ， 并 形成 预测 能 力 ? 

a 一 切 事物 的 网 络 化 : 世界 上 大 部 分 地 区 都 有 计算 机 网 络 , 无 论 人 们 使 用 的 是 像 
Facebook 这 样 的 社交 网 络 , 或 者 仅仅 通过 电子 邮件 交流 。 很 快 几乎 所 有 人 造 的 
物品 都 将 成 为 这 张大 网 的 一 部 分 ,从 我 们 穿 的 衣服 ,到 阅读 时 提供 照明 的 灯泡 。 
我 们 如 何 更 好 地 利用 这 个 超级 互 连 的 世界 ? 


无 论 最 终 的 答案 是 P= NP 还 是 PNP ， 对 这 一 问题 的 研究 过 程 本 身 都 将 在 很 大 
程度 上 影响 我 们 应 对 这 些 挑 战 的 方式 。 
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101 并 行 计算 


19654E, KI - 摩尔 注 意 到 一 种 称 为 晶体 管 的 基本 元 件 在 单 块 计算 机 芯片 上 的 数 
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量 每 年 都 在 急剧 增加 。 摩 尔 大 胆 预言 ， 单 块 芯 片上 的 晶体 管 数量 大 概 每 两 年 就 会 翻 一 
音 , 这 一 趋势 将 持续 至 少 10 年 的 时 间 。 现在 人 们 称 其 为 “摩尔 定律 ”"， 这 个 定律 从 1975 
年 直到 今天 都 有 效 ， 甚 至 在 今后 的 很 多 年 内 都 将 有 效 。 














在 很 长 一 段 时 间 里 ， 摩 尔 定律 意味 着 计算 速度 的 飞快 提升 。2005 年 前 后 ， 计 算 机 
开始 触及 物理 极限 , 即 让 处 理 需 跑 得 更 快 一 点 所 消耗 的 能 量 超过 了 提升 的 速度 能 够 带 
来 的 好 处 。 人 们 反而 要 稍微 降低 处 理 器 的 速度 ， 以 改进 能 源 的 消耗 。 











然而 我 们 还 是 往 芯 片 里 塞 更 多 的 晶体 管 。 要 这 么 多 晶体 管 做 什么 用 呢 ? 现在 这 些 
忆 片 在 同一 时 间 可 以 做 几 件 事 情 ， 以 并 行 的 方式 工作 ， 从 而 比 同 一 时 间 只 做 一 件 事 的 
方式 更 快 地 解决 问题 。 








让 我 们 来 看 一 台 特 殊 的 机 器 : IBM 公 司 的 华 生 ( Watson )。2011 年 2 月 ， 它 在 竞猜 
节目 Jeopardy 的 第 一 集中 得 了 冠军 。 华 生 由 90 台 IBM POWER 750 服 务 器 组 成 ， 每 台 都 
有 4 个 POWER7 处 理 器 。 一 个 POWER7 处 理 器 的 内 部 其 实 有 8 个 处 理 器 (也 叫 核心 )， 
所 以 它 能 同时 做 8 套 运算 。 这 样 ， 每 台 服 务 器 就 有 32 个 核心 ， 而 华 生 系统 一 共有 2880 
个 核心 。 华 生 能 同时 做 2880 套 计算 ,所 以 它 能 理解 Jeopardy 中 给 出 的 “答案 ”"， 并 判断 
每 一 环节 中 是 否 该 抢先 对 手 按 下 抢答 器 。 根 据 摩尔 定律 ， 在 不 远 的 将 来 ，2880 个 并 行 
处 理 核 心 显得 微不足道 ， 几 十 年 后 我 们 可 能 有 百 万 核 或 几 十 亿 核 的 计算 机 。 



























































并 行 技术 的 发 展 对 很 多 计算 机 科学 领域 提出 了 新 的 技术 要 求 。 一 台 计 算 机 如 何 决 
定 怎样 把 计算 量 在 数 个 核心 或 是 数 台 电脑 上 分 布 开 来 , 以 达到 最 佳 的 效能 ? 我 们 需要 
考虑 多 核 计算 机 因素 并 重 写 我 们 的 通用 编程 语言 吗 ? 如 果 需 要 ， 该 如 何 做 呢 ? 












































P/NP 问 题 同样 受到 并 行 技术 的 影响 。 记 得 本 书 开篇 提 到 的 《查理 和 巧克力 工厂 》 
中 的 小 女孩 维 鲁 卡 : 索 尔 特 吗 ?她 想 要 找到 藏 在 巧克力 包装 纸 里 的 金 券 。 她 爸爸 就 采 
用 了 并 行 技术 , 把 大 量 的 巧克力 分 配给 几 百 个 剥 花生 壳 的 工人 , 让 她 们 同时 来 找 金 券 。 
人 们 也 可 以 这 样 来 求解 NP 问题 ,把 所 有 可 能 是 团 的 集合 分 配给 儿 台 计算 机 以 及 每 台 计 
算 机 的 几 个 核心 。 这 可 能 会 让 一 个 持续 数 周 的 计算 在 儿 小 时 内 结束 ， 但 对 于 某 些 NP 
问题 的 求解 还 是 没什么 帮助 。 如 果 我 们 动用 100 万 台 计 算 机 ， 每 台 有 10 亿 个 核心 ,每 
个 核心 每 秒 能 进行 1 x 10“ 个 操作 , 仍然 需要 花费 几乎 10™ 倍 于 宇宙 寿命 的 时 间 。P/NP 
问题 在 并 行 的 世界 里 仍然 是 有 效 的 。 
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而 那些 P 类 的 问题 ， 即 我 们 能 高 效 地 解决 的 问题 又 怎么 样 呢 ? 我 们 能 最 大 限度 地 
利用 多 计算 机 和 多 处 理 器 的 优势 吗 ? 大 多 数 情况 下 我 们 可 以 通过 修改 算法 来 实现 这 
一 点 。 从 基本 的 算术 到 找 最 短路 径 再 到 匹配 问题 ， 所 有 这 些 问题 都 有 能 扩展 到 多 核 来 
并 行 计 算 的 算法 。 








像 P 和 NP 一 样 ,对 于 那些 能 用 并 行 算法 快速 解决 的 问题 集合 我 们 也 起 了 一 个 名 字 ， 
叫做 NC, 代表 Nick’s Class, 它 得 名 于 并 行 算法 的 先驱 尼古拉斯 - Hess. 如果 P=NC， 
那 任何 一 个 我 们 能 高 效 解决 的 问题 ， 都 能 通过 并 行 计算 更 快 地 解决 。 我 们 不 知道 是 否 
有 P=NC, 更 不 知道 是 否 有 NP =NC。NP =NC 意 味 着 每 一 个 NP 搜索 问题 都 能 用 极 快 的 
速度 在 并 行 计算 的 计算 机 和 (或 ) 核心 上 找到 有 效 的 解 ,这 预示 着 一 个 比 P = NP 更 加 
美妙 的 世界 。NP= NC 的 可 能 性 很 小 , 但 它 和 P= NP 一样 , 也 是 一 个 巨大 的 未 解 之 恋 。 









































10.2 ”处 理 大 数据 


在 1 秒 钟 的 时 间 里 ， 人 们 生成 了 35 分 钟 的 YouTube 视 频 、1600 条 Twitter 上 的 消息 、 
11 000 条 Facebook 消 息 、50 000 次 Google 搜 索 请 求 ， 以 及 300 万 封 电子 邮件 (不 过 其 中 
90% 都 是 垃圾 邮件 )。 

















哈 勃 望远镜 从 它 的 轨道 扫描 太空 ， 每 秒 传 回 20 万 字 节 的 消息 。!1 字 节 数 据 大 概 就 
是 1 个 字母 。 哈 勃 望 远 镜 的 继任 者 久 姆 斯 ， 韦伯 太空 望远镜 拥有 更 大 的 抛物 线形 的 镜 
片 ， 每 秒 将 向 地 球 传 回 350 万 字 节 的 数据 。 
































坐落 在 法 国 和 瑞士 边境 线 上 的 大 型 强 子 对 撞 机 (LHC ) 是 世界 上 最 大 的 粒子 加 速 
顺 。 它 平均 每 秒 生成 5 亿 字 节 的 数据 ， 每 一 年 的 每 一 秒 都 是 如 此 ， 而 一 年 有 3100 万 秒 。 








CERN 即 欧洲 核子 研究 组 织 ， 它 是 大 型 强 子 对 撞 机 的 建造 者 和 维护 机 构 。 那 里 的 
科学 家 们 还 建造 了 一 个 LHC 计算 网 格 , 将 产生 的 大 量 数据 分 发 到 位 于 34 个 国家 的 服务 
如 上 ， 让 全 世界 的 科学 家 都 能 访问 并 分 析 LHC 的 数据 。 








人 类 DNA 序 列 包含 大 概 5500 万 字 节 的 信息 。 全 世界 70 亿 人 的 基因 序列 大 概 包含 
4x 10 比特 的 信息 。 这 还 只 是 人 类 一 个 物种 。 




















我 们 很 容易 就 能 制造 各 种 廉价 的 传感器 , 测量 从 温度 到 动作 、 从 声音 到 辐射 的 各 
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种 事物 。 每 一 个 传感器 都 在 持续 生成 信息 ， 而 实际 中 通常 会 使 用 上 千 个 传感器。 有 人 
形容 美国 军队 “在 传感器 里 游泳 ， 在 数据 里 渡 死 "。 





不 是 所 有 数据 都 来 自 外 部 世界 。 许 多 科学 实验 实际 操作 起 来 十 分 困难 或 者 成 本 昂 
贵 ， 于 是 人 们 借助 计算 机 来 进行 仿真 实验 ， 也 可 以 了 解 生 物 学 、 物 理学 和 化 学 系统 中 
的 各 种 交互 作用 。 这 些 仿真 实验 同样 生成 了 大 量 的 有 待 分 析 的 数据 。 












































上 述 各 种 来 源 的 数据 虽然 数量 很 大 , 但 其 中 大 部 分 都 是 无 用 信息 ， 有 的 是 随机 品 
Pi, 还 有 的 是 宛 余数 据 。 找 到 数据 集中 关键 而 有 用 的 部 分 是 很 困难 的 ， 并 且 需 要 对 信 
息 的 深度 解读 。 如 果 P= NP , 我 们 只 要 用 算法 把 数据 过 一 遍 ,， 就 能 挑 出 其 中 重要 的 部 
分 ， 再 使 用 基于 奥 卡 姆 剃刀 法 则 的 工具 ， 就 能 形成 对 数据 的 理解 和 预测 能 









































而 我 们 不 太 可 能 生活 在 那样 一 个 美妙 的 世界 ,我 们 只 能 尽量 根据 实际 需求 寻找 和 修 
改 我 们 的 算法 。 从 大 量 的 数据 中 理 出 头绪 是 一 个 非常 困难 、 但 也 十 分 重要 的 计算 问题 。 























大 数据 往往 是 好 事 , 尤其 是 在 机 顺 学 习 领 域 。 机 融 学 习 研 究 的 是 如 何在 给 定 的 数 
据 集 上 训练 算法 。 拥 有 的 数据 越 多 ， 训 练 出 的 算法 就 越 好 。 通 常 ， 拥 有 更 多 数据 胜 过 
拥有 更 好 的 算法 。Google 在 垃圾 邮件 检测 、 语 音 识别 和 语言 翻译 等 方面 能 有 不 错 的 表 
现 ， 靠 的 就 是 它 所 能 使 用 的 大 量 样 例 数据 。 



































在 不 远 的 将 来 ,我 们 拥有 的 数据 将 帮助 我 们 更 好 地 分 析 个 人 健康 状况 ， 建 造 更 智 
能 和 节能 的 电力 网 络 ， 也 将 让 自动 驾驶 的 汽车 得 到 普及 ,并 让 我 们 对 所 处 的 宇宙 的 基 
本 性 质 有 更 深 的 了 解 。 如 何 理解 数据 以 更 好 地 丰富 人 们 的 生活 ， 是 计算 机 科学 家 面临 
的 一 大 挑战 。 























10.3 一 切 事 物 的 网 络 化 





全 世界 大 概 有 20 亿 人 通过 互联 网 彼此 联系 ,如 电子 邮件 或 社交 网 络 。 如 今 互 联网 
带 给 我 们 的 交流 、 合 作 、 学 习 和 休闲 方式 ， 是 在 20 世 纪 不 可 想象 的 。 











如 果 我 们 把 各 种 物品 也 放 到 互联 网 上 会 发 生 什么 ?在 不 久 的 将 来 , 我们 将 拥有 各 
种 能 上 网 的 小 型 廉价 蕊 片 , 无 论 是 通过 Wi-Fi、 移动 蜂窝 网 络 , 还 是 通过 其 他 正在 研发 
的 无 线 通 信 系 统 。 我 们 能 把 这 些 芯 片 放 到 几乎 任何 东西 里 ， 从 我 们 穿 的 衣服 到 我 们 开 
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的 车 ， 再 到 我 们 买 的 食品 的 包装 。 你 不 用 纸 笔 做 记录 就 能 追踪 一 切 ， 从 孩 子 们 是 否 系 
好 安全 带 到 你 每 天 卡路里 的 摄 和 人 量 。 没 有 牛奶 或 洗 发 液 J 了 ? 别 担心 ,补给 品 已 经 自动 
> 货 ， 正 在 到 你 家 的 路 上 。 你 再 也 不 会 误 服 药品 了 。 你 穿 的 衣服 会 告诉 你 它们 是 否 适 
合 特定 的 场合 和 天 气 ， 或 者 会 说 :“ 你 真 的 想 穿 这 件 衬衫 来 搭配 这 条 裤子 吗 ?” ”这 对 
于 那些 色盲 人 士 或 者 不 懂 服 装 搭配 的 人 一 定 大 有 神 益 。 

















你 再 也 不 会 丢 钥 是 、 钱 包 、 门 票 , 或 者 任何 其 他 的 东西 了 。 你 其 至 都 不 用 携带 这 
些 东西 。 手 机 发 一 个 信号 就 能 让 你 家 门 锁 在 你 接近 时 打开 。 自 动 取款 机 直接 会 把 钱 交 
到 你 手 上 。 你 可 以 从 商店 里 拿 起 东西 就 走 。 所 有 的 付款 和 扣 费 都 是 自动 发 生 的 。 








上 述 场景 的 实现 需要 所 有 的 设备 都 能 彼此 协作 ， 并 拥有 良好 的 配合 意识 。 需 要 研 
发 出 一 种 合理 的 方式 ， 让 这 些 设备 能 够 交换 信息 ， 同 时 保护 个 人 的 隐私 。 我 们 将 在 前 
所 未 有 的 程度 上 实现 协同 。 想 象 如 果 所 有 的 汽车 能 够 彼此 合作 ， 交 通 该 有 多 顺畅 。 而 
这 些 进 步 的 实现 ， 都 要 求 算法 能 对 某 些 大 规模 问题 进行 快速 、 稳 定 和 持续 的 求解 。 除 
非 交 通 系 统 能 够 快速 响应 ， 否 则 一 次 很 小 的 交通 事故 也 可 能 造成 大 面积 的 交通 次 疾 。 
这 些 问 题 中 一 部 分 涉及 了 P/NP 问 题 ， 而 我 们 只 能 尽 最 大 努力 去 处 理 好 它们 。 




















Sun 公 司 ( 现在 是 甲骨 文公 司 的 一 部 分 ) 在 20 世 纪 90 年 代 有 一 名 口号 :“ 网 络 即 计 
算 机 。” 网 络 上 彼此 独立 工作 的 机 器 通过 协作 ， 在 整体 上 可 被 看 做 一 个 计算 设备 。 当 
一 切 事物 都 能 被 网 络 化 ， 我 们 就 有 了 一 个 非常 大 的 计算 机 。 驯 服 这 头 猛 兽 虽 然 不 易 ， 
但 它 也 将 为 我 们 撞 开 一 肩 充 满 新 的 机 遇 的 大 门 。 














10.4 ”应 对 科技 变革 





并 行 计算 、 大 数据 和 一 切 事物 的 网 络 化 并 不 只 是 出 现在 科幻 作品 中 的 概念 。 它 们 
更 是 一 场 早 已 开始 的 变革 的 宣言 ， 而 这 场 变 草 将 在 未 来 的 一 二 十 年 里 横扫 世界 。 社 会 
将 会 发 生 怎样 的 变化 ? 








几乎 不 可 能 事先 预测 某 项 科技 创新 对 于 社会 的 巨大 影响 力 。 在 20 世 纪 50 年 代 ， 经 
营 着 一 家 卡车 公司 的 马尔 科 姆 .麦克 莱恩 发 明了 一 种 不 用 御 货 就 能 直接 从 轮船 移动 到 
卡车 上 的 集装箱 。 他 的 发 明 推 动 了 运输 业 的 一 场 革命 , 在 这 场 革命 中 诞生 了 可 容纳 上 
和 干 个 集装箱 的 巨型 轮船 ， 也 孕育 了 不 需要 任何 码头 工人 就 能 运转 的 自动 化 港口 。 这 个 
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历史 事件 在 当时 的 文化 产物 中 也 有 所 体现 ， 如 电影 《码头 风云 》( On the Waterfront ) 
和 电视 剧 《 一 家 子 》(41 in the Fam 妙 )。 这 跟 中 国 的 崛起 也 有 一 定 的 关系 ， 借 助 一 个 
个 钢 制 的 箱子 ， 中 国 将 出 产 的 货物 运送 到 了 世界 各 地 。 





























汽车 推动 了 郊区 的 崛起 。 手 机 意味 着 我 们 再 也 不 用 提前 做 好 计划 。Twitter 帮 助人 
民 推 翻 了 政府 的 统治 。 科 技 对 人 类 的 影响 体现 在 各 种 难以 预料 的 方面 。 人 们 最 好 做 好 
准备 ， 因 为 这 一 切 马上 就 要 再 次 发 生 。 





除了 要 考虑 计算 的 问题 , 我们 还 需要 考虑 人 的 因素 。 人 们 总 会 利用 新 的 科技 做 一 
事 ， 有 的 人 是 无 意 的 ， 另 一 些 人 则 是 故意 为 之 。 我 们 还 需要 具备 符合 人 们 认 知 好 
辑 的 良好 产品 设计 ， 让 人 们 能 轻松 地 上 手 使 用 新 一 代 的 科技 设备 ， 尽 可 能 不 要 让 学 习 
曲线 太 陡 。 
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可 能 会 有 人 淮 试 控制 科技 ， 其 动机 有 可 能 是 出 于 个 人 利益 , 还 有 可 能 是 为 了 获取 

息 。 最 坏 的 可 能 性 是 人 们 会 用 科技 制造 麻烦 。 有 些 麻 烦 无 伤 大 雅 ， 只 是 比较 
烦人 而 已 ， 另 一 些 则 会 造成 大 量 的 财产 损失 ， 甚 至 造成 人 员 伤 亡 。 为 了 阻止 某 些 人 利 
用 科技 手段 制造 社会 灾难 ， 人 们 有 必要 加 强 密码 学 和 安保 措施 的 研究 和 使 用 ， 并 且 时 
刻 保持 警惕 。 











需要 注意 的 是 ， 当 一 项 科技 在 大 部 分 情况 下 都 表现 良好 时 ， 大 家 会 误 以 为 它 能 在 
所 有 情况 下 都 表现 良好 , 这 也 许 是 其 最 危险 的 一 面 。 如 果 人 们 对 科技 投入 过 多 的 信任 ， 
它 可 能 就 会 在 大 家 毫 无 防备 的 时 候 突然 掉 链 子 。 未 曾 预料 到 的 罕见 事件 的 发 生 会 加 剧 
这 个 问题 的 严重 程度 。 一 些 例子 包括 : 卡特 里 娜 飓风 袭击 下 新 奥尔良 市 的 防洪 志 决 口 ， 
2010 年 深水 地 平 线 ( Deepwater Horizon ) 公司 的 钻井 平台 爆炸 之 后 大 量 原油 泄漏 的 事 
故 ， 以 及 2011 年 日 本 地 震 和 海啸 之 后 福 岛 核电 站 核 泄漏 灾难 。 我 们 应 该 像 对 待 未 被 驯 
服 的 猛兽 那样 正视 科技 的 力量 与 危险 性 。 发 生 大 规模 科技 事故 的 概率 虽然 很 小 , 但 仍 
有 可 能 性 。 人 们 要 警惕 不 要 让 科技 事故 酝酿 出 更 加 巨大 的 灾难 。 

































































10.5 “关于 P/NP 问 题 的 结束 语 








HEHH P x NP 并 非 易 事 。 你 需要 证 明 不 存在 有 效 的 算法 能 解决 团 问题 或 任何 其 他 的 
NP 完 全 问题 , 这 些 算 法 既 包 括 现 有 的 也 包括 将 来 发 明 的 。 如 何 证 明 每 一 个 潜在 的 算法 
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都 必 将 失败 ? 





人 们 相信 这 样 的 证 明 总 有 一 天 会 出 现 , 但 有 可 能 需要 过 上 20 年 , 200 年 , 甚至 2000 
年 。 总 有 一 天 ， 当 人 们 发 展 出 的 新 技术 最 终 能 证 实 Pz NP 的 时 候 , 数学 家 们 会 兴 高 采 
烈 , 为 一 个 伟大 的 问题 得 到 一 个 伟大 的 解答 而 欢呼 。 而 求解 P/NP 问 题 过 程 中 产生 的 技 
术 将 让 我 们 深刻 认识 高 效能 计算 的 威力 ， 这 种 东西 会 渗透 到 社会 生活 的 方方面面 。 





P/NP 问 题 远 远 不 只 是 一 个 数学 迹 题 那么 简单 。 它 是 一 种 思考 的 方法 , 一 种 根据 问 
题 的 内 在 难度 对 其 进行 分 类 和 认识 的 方法 。 虽然 尚 没 有 Pz NP 的 确凿 证 据 , 我 们 起 码 
知道 了 : 当面 临 一 个 NP 完全 问题 时 , 不 可 能 找到 一 个 在 所 有 情况 下 都 能 解决 该 问题 的 
算法 。 这 时 就 需要 借助 于 其 他 的 工具 ， 如 近似 计算 、 启 发 式 方法 、 暴 力 破解 等 方法 的 
组 合 , 然后 尽 我 们 所 能 地 争取 最 好 的 结果 。NP 完 全 性 理论 给 了 我 们 一 个 通用 的 思考 框 
架 ， 人 允许 我 们 建立 一 套 由 很 多 技术 组 成 的 工具 体系 ， 向 那些 难以 计算 的 问题 发 起 有 效 
的 攻击 。 

















P/NP 问 题 让 学 术 界 团结 在 一 起 。 物 理学 、 生 物 学 、 经 济 学 以 及 其 他 许多 领域 中 都 
有 NP 完全 问题 的 身影 。 虽然 物理 学 家 和 经 济 学 家 所 关注 的 问题 有 很 大 的 差异 , 但 这 两 
类 问题 也 存在 着 共性 。 所 以 分 享 各 自 的 工具 和 技术 将 为 双方 都 带 来 巨大 的 好 处 。 例 如 ， 
物理 学 中 为 了 寻找 物理 系统 的 基态 而 开发 的 工具 , 对 于 经 济 学 中 寻找 复杂 经 济 环 境 中 
可 能 出 现 的 均衡 行为 也 是 有 帮助 的 。 























P/NP 问 题 内 在 的 难度 同样 促进 了 新 技术 的 发 展 。 当代 密码 学 家 从 PINP 问 题 受到 启 
发 ,把 密码 学 操作 过 程 从 一 门 艺术 变 成 了 科学 。 对 于 解决 PNP 问 题 的 强烈 需求 也 在 激 
励 人 们 建造 更 快 、 更 强 的 计算 系统 ， 催 生 了 诸如 量子 计算 这 样 的 新 技术 。 








计算 是 一 种 和 过 程 有 关 的 活动 ， 而 过 程 不 仅仅 出 现在 计算 机 上 。P/NP 问 题 归 根 到 
底 与 自然 本 身 的 极限 有 关 ， 与 生物 和 物理 系统 进化 的 极限 有 关 ， 甚 至 可 以 说 与 人 类 思 
想 所 能 达到 的 极限 有 关 。 只 要 P/NP 问 题 还 是 一 个 未 解 之 访 , 人 类 就 无 法 确切 地 知道 自 
己 所 能 取得 的 成 就 的 极限 在 哪里 。 这 不 由 得 让 人 感到 精神 一 振 。 

















章 市 注释 和 文献 








本 书 的 内 容 基 于 我 对 计算 复杂 度 领域 的 研究 经 验 , 以 及 与 儿 千 个 来 自学 术 界 和 工业 
界 同样 对 P/NP 问题 感 兴趣 的 研究 者 。 书 中 的 一 些 内 容 改 编 自我 的 博客 “Computational 
Complexity" ( 计算 复杂 度 )。 




















在 著 书 过 程 中 ,我 从 许多 资料 引用 了 一 些 故事 、 例 子 和 结果 。 下 面 将 列 出 所 有 的 
资料 。 


所 有 对 于 这 些 资料 或 链接 的 更 新 ,以 及 文中 发 现 的 重大 错误 ,都 将 公布 在 本 书 的 
网 站 http://press.princeton.edu/titles/9937.html 上 。 网 站 也 提供 了 引用 的 图 书 、 访谈 、 附 
加 信息 以 及 P/NP 问题 的 拓展 阅读 等 内 容 。 
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Lance Fortnow, “The Status of the P versus NP Problem, " Communications of the ACM 
52, no. 9 (September 2009): 78—86. 


Stephen Hawking, 4 Brief History of Time: From the Big Bang to Black Holes (New 
York: Bantam Dell, 1988). 


第 1 章 




















维 露 卡 : 索 尔 特 的 故事 是 从 罗 尔 德 . 达尔 的 小 说 Charlie and the Chocolate Factory 
(New York: Knopf, 1964) 中 摘录 的 。 

对 松 冈 容 子 工作 的 讨论 ， 即 她 的 科研 小 组 研发 的 解剖 学 上 正确 无 误 的 机 械 手 , 信 
息 来 自 2010 CRA Snowbird Conference (2010 年 7 月 18 日 ) 上 的 一 场 讲座 。 
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第 2 章 
除了 2.4 节 ,本 章 其 余 内 容 都 是 我 虚构 的 ,目的 是 为 了 描绘 不 太 可 能 发 生 的 P= NP 
的 世界 。 























第 3 章 
关于 米尔 格拉 姆 的 实验 ， 参 见 Stanley Milgram, “The Small World Problem, " 
Psychology Today 2, no. 1 (1967): 60-67。 


贝 肯 分 数 的 计算 来 自 Internet Movie Database; 





对 于 四 色 问 题 有 一 本 可 读 性 更 强 的 故事 ， 参 见 Robin Wilson, Four Colors Suffice: 
How the Map Problem Was Solved (Princeton, NJ: Princeton University Press, 2004), 


第 4 章 


引用 库 克 的 话 其 实 有 修改 ， 经 过 了 一 些 现代 术语 的 替换 。 原 文 如 下 : 








The theorems suggest that {tautologies} is a good candidate for an interesting set not in 
L*, and I feel it is worth spending considerable effort trying to prove this conjecture. Such a 


proof would be a major breakthrough in complexity theory. 


Steve Cook, “The Complexity of Theorem-Proving Procedures, " in Proceedings of the 


Third Annual ACM Symposium on Theory of Computing (New York: ACM), 151—158. 

















卡 普 的 后 续 论文 指 的 是 : Richard Karp, *Reducibility among Combinatorial Problems, ” 
Complexity of Computer Computations 40, no. 4 (1972): 85—103。 


Bob Sehlinger (author) and Len Testa (contributor), The Unofficial Guide Walt Disney 
World 2010 (New York: Wiley, 2010). 


4.3 节 内 容 取 材 自 Donald Knuth, “A Terminological Proposal, " ACM SIGACT News 6, 
no. 1 (January 1974): 12-18, 


Kevin Sack, “60 Lives, 30 Kidneys, All Linked, " New York Times, February 19, 
2012, A1. 
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第 5 章 
本 章 从 以 下 资料 汲取 了 很 多 素材 。 


Lance Fortnow and Steve Homer, “A Short History of Computational Complexity, ” 
Bulletin of the European Association for Theoretical Computer Science 80 (June 2003), 
"Computational Complexity? 专栏 ， 以 及 与 许多 研究 者 的 个 人 讨论 ( 包括 斯 蒂 芬 * 库 克 
和 列 昂 尼 德 . 莱 文 )。 


Dennis Shasha and Cathy Lazere, “A Good Solution Is Hard to Find, " in Out of Their 


Minds: The Lives and Discoveries of 15 Great Computer Scientists (New York: Springer, 1995). 


Juris Hartmanis, “Observations about the Development of Theoretical Computer 


Science, " Annals of the History of Computing 3, no. 1 (January 1981): 42—51. 


B. A. Trakhtenbrot, *A Survey of Russian Approaches to Perebor (Brute-Force Search) 
Algorithms, " Annals of the History of Computing 6, no. 4 (October 1984): 384—400. 


Michael Sipser, “The History and Status of the P versus NP Question, ”in Proceedings 
of the 24th Annual ACM Symposium on Theory of Computing (New York: ACM, 1992), 
603-618. 这 篇 文章 中 包含 了 哥 德 尔 写 给 冯 诺 依 曼 的 信件 副本 和 英文 译文 。 

















柯 尔 莫 哥 洛 夫 曾 经 试图 成 为 历史 学 家 的 故事 得 到 了 几 个 俄罗斯 人 的 印证 , 时 间 是 
在 2003 年 4 月 27 日 至 5 月 2 日 ,地 点 是 在 德国 的 Dagstuhl 召开 的 柯 尔 莫 哥 治 夫 复杂 
度 及 应 用 百年 座谈 会 上 。 这 个 故事 也 记录 在 我 的 博客 “Computational Complexity” E, 
时 间 是 2003 年 5 月 1 日 。 
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旅行 推销 员 问 题 * 的 例子 来 自 “CRPC Researchers Solve Traveling Salesman Problem 
for Record-Breaking 13,509 Cities", 2003 年 由 莱 斯 大 学 并 行 计算 研究 中 心 举 行 的 一 次 
新 闻 发 布 会 。 

















为 了 找到 地 图 填 色 的 启发 式 方法 的 例子 , 我 向 网 络 社区 寻求 了 帮助 ， 在 答疑 网 站 
( http://cstheory.stackexchange.com/questions/4027/coloring-planar-graphs ) 和 我 的 博客 上 























Qa 旅行 推销 员 问 题 是 用 Mark Daskin 的 软件 生成 的 ， 网 址 是 http:/sitemakerumich. edu/msdaskin/software。 
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发 布 了 帖子 。 





敌 友 国 各 省 地 图 取材 于 于 David P. Dailey, “Uniqueness of Colorability and 
Colorability of Planar 4-Regular Graphs Are NP-Complete", Discrete Mathematics 30 
(1980): 289-293, 





第 7 章 
第 一 句 中 引用 尤 里 斯 ， 哈 特 马 尼 斯 的 话 来 自 于 他 1985 年 春季 在 康 奈 尔 大 学 讲 的 
— RES 






































关于 PNP RK, ZL JACM 的 相关 页 面 (http:/jacm.acm.org/instructions/pnp )。 


维 纳 里 ， 德 奥 拉 利 卡 的 P/NP 论文 附加 在 他 于 2010 年 8 月 6 日 发 送 的 一 封 电子 邮 
件 中 ， 收 信人 是 我 和 其 他 21 个 研究 者 。 





吉 罗 拉 莫 的 故事 参见 David Kahn, The Codebreakers: The Story of Secret Writing 
( New York: Macmillan, 1967 )。 


第 8 章 
本 章 关于 密码 学 早期 历史 的 叙述 很 多 都 来 自 David Kahn 的 著述 ,The Codebreakers: 
The Story of Secret Writing (New York: Macmillan, 1967)。 





零 知 识 证 明 数 独 的 例子 源 于 我 在 2006 年 8 月 3 日 撰写 的 一 篇 博文 ,发 布 在 我 的 博 
客 “Computational Complexity” E: http://blog.computationalcomplexity.org/2006/08/zero- 
knowledge-sudoku.html。 
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Signatures and Public-Key Cryptosystems," | Communications of the ACM 21, no. 2 
(February 1978): 120—126. 
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我 对 理 查 德 . 费 曼 在 量子 计算 中 起 到 的 作用 的 叙述 取材 自 David Deutsch 的 著作 ， 
"Quantum Computation," Physics World, January 6, 1992, 
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Charles Bennett and Gilles Brassard, "Quantum Cryptography: Public Key Distribution 
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and Co., 2006), 151, for the Bennett and Brassard beach story. 


Peter Shor, "Polynomial-Time Algorithms for Prime Factorization and Discrete Loga- 


rithms on a Quantum Computer," SIAM Journal on Computing 26 (1997): 1484-1509. 





摩尔 定律 来 自 Gordon Moore, “Cramming More Components onto Integrated 


Circuits," Electronics 38, no. 8 (April 19, 1965), 








华 生 的 硬件 配置 公布 在 IBM HJ "What Runs IBM Watson and Why” 博 文中 ， 作 者 


是 David Davidian。 
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集装箱 的 故事 来 自 Marc Levinson, The Box: How the Shipping Container Made the 
World Smaller and the World Economy Bigger (Princeton, NJ: Princeton University Press, 
2008). 


大 数据 的 统计 信息 的 来 源 
http://www.youtube.com/t/press statistics 


http://techcrunch.com/2011/03/14/new-twitter-stats- 140m-tweets-sent-per-day-460k- 


accounts-created-per-day/ 
http://www.facebook.com/press/info.php?statistics 
http://email.about.com/od/emailtrivia/f/emails per day.htm 
http://public.web.cern.ch/public/en/Ihc/Computing-en.html 
http://space.about.com/od/telescopesandoptics/p/hubbleinfo.htm 
http:;//webbtelescope.org/webb telescope/technology at the extremes/quick facts.php 


http://royal.pingdom.com/2011/01/12/internet-2010-1n-numbers/ 
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他 的 生平 、 思 想 及 论文 解读 


| EN Y 


阿兰 . 图 灵 ( 1912 一 1954 ) 是 英国 数学 家 、 逻 辑 学 
家 ， 被 称 为 计算 机 科学 之 父 、 人 工 智 能 之 父 ， 是 计 
算 机 远 辑 的 莫 基 者 ， 提 出 了 “图 灵机 ”和 “图 灵 测 
试 ” 等 重要 概念 。 本 书 讲述 图 灵 的 传奇 一 生 ， 巨 细 
靡 遗 地 为 读者 展现 他 天 才 般 的 洞 见 。 


你 或 许 知道 旅行 商 问 题 的 起 源 和 历史 ， 但 可 能 没 想 
到 它 的 应 用 范围 如 此 之 广泛 ， 涉 及 基因 组 测序 、 计 
算 机 处 理 器 设计 、 音 乐 整理 、 行 星 寻 找 …… 更 炫 的 
是 ， 离 开 计 算 机 ， 这 个 问题 一 样 能 解决 ， 翻 开 它 ， 
一 起 寻找 更 刺激 的 答案 。 





"Fortnow E IE fif 8] T 5| A. 
入 胜 ， 读 者 沉迷 于 P/NP 问 题 的 神 
秘 与 重要 性 之 中 难以 自拔 。” 


“Fortnow 的 著作 是 一 张 入 
场 券 ， 它 把 我 们 这 个 时 代 面 临 的 
最 难 的 理论 问题 降 到 一 般 民 众 的 
认 知 水 平 来 演绎 ， 甚 至 连 政客 们 
都 看 得 懂 。” 


“这 是 一 个 神秘 、 艰 难 、 令 
人 肖 丧 的 世界 ， 这 是 一 个 探索 和 
发 现 的 世界 ， 这 是 一 个 喜悦 和 意 
外 迟 来 的 世界 ， 这 是 Fortnow 眼 中 
的 PINP 世 界 。” 


“P/NP 问 题 的 定义 原本 极其 
专业 和 刁钻 ,但 Fortnow 不 仅 具 有 
化 繁 为 简 的 能 力 ， 还 能 虚实 结 
合 、 融 会 贯通 ， 将 该 问题 的 重要 
性 描述 得 淋漓 尽 致 。” 





图 灵 社 区 : www.ituring.com.cn 


新 浪 微 博 : @ 图 灵 教育 @ 图 灵 社 区 @ 图 灵 新 知 
反馈 /投稿 /推荐 信箱 : contact@turingbook.com 


热线 : (010)51095186 转 600 


科普 读物 /数学 
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计算 机 /基础 入 门 
人 民 邮 电 出 版 社 网 址 : www.ptpress.com.cn 
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“我 敢 打赌 你 会 爱 上 这 本 书 。 它 通俗 易 懂 ， 把 一 个 顶尖 数学 问题 演 

绎 得 跌宕 起 伏 ， 读 者 时 而 充满 期 待 、 为 之 感到 兴奋 ， 时 而 又 黯然 神伤 。 
REKE, 我 有 几 分 期 待 P 不 等 于 NP 了 。” 

一 一 Vint Cerf，Google 副 总 裁 、 首 席 互联 网 布道 师 、 互 联网 之 父 


“P/NP 问 题 是 计算 机 科学 乃至 整个 数学 的 基础 。 本 书 对 该 问题 的 痢 
释 令 人 着 迷 ， 既 追溯 了 其 历史 ， 也 探讨 了 其 现状 与 影响 。 行文 过 程 中 涉 
及 许多 大 学 计算 机 科学 的 研究 主题 ,语言 风趣 幽默 ， 读 者 不 需要 有 多 么 
高 深 的 数学 知识 ， 只 要 会 解数 独 游戏 即 可 畅 读 。 我 强烈 推荐 。” 

一 一 Stephen Cook，P/NP 问 题 的 构造 者 


“Fortnow 是 一 位 世界 级 计算 机 科学 专家 ， 他 通过 本 书 详 述 了 该 领域 
最 负 盛 名 和 意义 最 为 重大 的 一 个 未 解难 题 。 作 者 向 普通 大 众 深 入 浅 出 地 
讲解 了 计算 复杂 性 这 个 看 似 神秘 的 领域 ， 对 于 “什么 是 可 计算 的 ， 能 
得 多 快 ' 这 类 问题 感 兴趣 的 读者 可 以 一 饱 眼福 。?” 
一 一 John MacCormick，《 改 变 未 来 的 九 大 算法 》 作 者 


“对 于 P/NP 问 题 的 重要 性 ，Fortnow 作 了 最 好 的 诠释 。” 
一 一 Wiliam J. Cook, 
《迷茫 的 旅行 商 : 一 个 无 处 不 在 的 计算 机 算法 问题 》 作 者 


“本 书 巨 细 摩 遗 ， 对 于 P/NP 这 个 历久 弥 新 的 重大 话题 ， 作 者 详尽 追 

溯 了 其 发 展 历史 和 学 术 背 景 。 即 使 是 复杂 性 理论 学 家 也 能 从 本 书 获 益 ， 
而 向 普罗 大 众 介绍 复杂 性 理论 ， 本 书 可 谓 开山 之 作 ! ” 

一 一 William Gasarch， 马 里 兰 大 学 教授 
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图 灵 社 区 


电子 书 发 售 平台 


电子 出 版 的 时 代 已 经 来 临 ， 在 许多 出 版 界 同行 还 在 犹 移 仿 得 的 时 候 ， 图 灵 社 区 
已 经 采取 实际 行动 拥抱 这 个 出 版 业 巨变 。 相 比 纸 质 书 ， 电 子 书 具 有 许多 明显 的 
优势 。 它 不 仅 发 布 快 ， 更 新 容易 ， 而 且 尽 可 能 采用 了 彩色 图 片 〈 即 使 有 的 书 纸 
质 版 是 黑白 印刷 的 ) 。 读 者 还 可 以 方便 地 进行 搜索 、 剪 贴 、 复 制 和 打印 。 


图 灵 社区 进一步 把 传统 出 版 流程 与 电子 出 版 业务 紧密 结合 ， 目 前 已 实现 作 译 者 
网 上 交 稿 、 编 辑 网 上 审 稿 、 按 章 发 布 的 电子 出 版 模式 。 这 种 新 的 出 版 模式 ， 我 
们 称 之 为 “敏捷 出 版 ”， 它 可 以 让 读者 以 较 快 的 速度 了 解 到 国外 最 新 技术 图 书 
的 内 容 ， 弥 补 以 往 翻译 版 技术 书 “ 出 版 即 过 时 ”的 缺憾 。 同 时 ， 敏 捷 出 版 使 得 
作 、 译 、 编 、 读 的 交流 更 为 方便 ， 可 以 提前 消灭 书稿 中 的 错误 ， 最 大 程度 地 保 
证 图 书 出 版 的 质量 。 


开放 出 版 平台 


图 灵 社 区 向 读者 开放 在 线 写 作 功 能 ， 协 助 你 实现 自 出 版 的 梦想 。 你 可 以 联合 二 
三 好 友 共 同 创作 一 部 技术 参考 书 ， 以 免费 或 收费 的 形式 提供 给 读者 ， 这 极 大 地 
降低 了 出 版 的 门槛 。 成 熟 的 书稿 ， 有 机 会 入 选 出 版 计划 ， 同 时 出 版 纸 质 书 。 


图 灵 社 区 引进 出 版 的 外 文 图 书 ， 都 将 在 立项 后 马上 在 社区 公布 。 如 果 有 意 翻 译 
哪 本 图 书 ， 欢 迎 来 社区 申请 。 只 要 通过 试 译 的 考验 ， 即 可 签约 成 为 图 灵 的 译 者 。 
当然 ， 要 想 成 功 地 完成 一 本 书 的 翻译 工作 ， 是 需要 有 坚强 的 妆 力 的 。 


读者 交流 平台 


在 图 灵 社区 ， 读 者 可 以 十 分 方便 地 写作 文章 、 提 交 勘 误 、 发 表 评论 ， 以 各 种 方 
式 与 作 译 者 、 编 辑 人 员 和 其 他 读者 进行 交流 互动 。 提 交 勘 误 还 能 够 获 赠 社区 银 
子 。 欢 迎 大 家 积极 参与 社区 开展 的 访谈 、 审 读 、 评 选 等 多 种 活动 ， 赢 取 银 子 ， 
可 以 换 书 哦 ! 


